الأسس العلمية لقواعد البيانات - منتديات الفريق العربي للبرمجة 
InternetMaster‏ 


مشاركات في عام(2003) ليس لها مثيل بواسطة خبير قواعد البيانات : 


InternetMaster 
. تم تجميعها من قبلي لتعم الفائدة للجميع‎ 
وقد بين في احدى المشاركات عدم ممانعته تجميع المشاركات و نشرها‎ 


عماد حمدي يوسف 
العراق بغداد 
2010/03/04 


مرحباء»» 


يبدو أنني ممن إنضم لهذا الموقع متأخراً بعض الشيء حيث لم أسمع به من 
قبل» ويظهر من قراءتي لبعض المشاركات أنئي قد فقدت فترة إزدهار هذا 
الموقع!! 


بعد إنضمامي ببضعة أيام ومحاولاتي للإجابة على بعض أسئلة زوار الموقع 
إتضخ لذي أن هناك كلد في الفاح الأساسية لر اغد اينات 


وعليه فقد طلب مني بعض الأخوة في هذا الموقع شرح الأسس العلمية لقواعد 
البيانات وحيث أن لدي وقتا لعمل هذا حتى 15 رمضان فسأحاول جهدي أن 
أضع بين أيدي زوار الموقع ومنسوبيه خبرة أكثر من 20 عاما في البرمجة. 
و سنركز على جزئية قواعد البيانات بالدرجة الاولى. 

في هذه الدروس السريعة حتى يصل معنا بمشيئة الله إلى المفاهيم الصحيحة 
لقواعد البيانات. 


كل ما أطلبه ممن يستفيدوا من هذه الشروحات المتواضعة هو دعوات صادقة 
لي في هذه الأيام المباركةء أم من لم يستفد فآمل منه أن يتقبل إعتذاري على 
إضاعة وقته. 


فبإسم الله نبدا وعليه نتوكل. 


تحیاتی›»› 


مرحباء»» 


في البداية آمل ممن يقرا هذه الوريقات أن يتنبه إلى أنني وضعت هذه الدروس 
في قسم 5ء ع٥٥۸‏ لكثرة عدد الزوار في هذا القسم» وعليه فالشرح هنا يتحدث 
عن قواعد البيانات بالدرجة الأولى وليس عن نوع واحد فقط عند تعلماک 
للأسس الصحيحة لقواعد البيانات تصبح البرامج التالية في منتهى السهولة 
والبساطة. 


Access 
FoxPro 
Clipper 
DBase 


Microsoft SQL 
Oracle 
Sybase 


كل ما سبق عبارة عن برامج لشركات مختلفة تستخدم أدوات قواعد البيانات» 
للتوضيح يوجد مصطلح" سيارة "فعند التحدث عن السيارة يكون عن كيفية 
علا ونا عا وض اها ر را بكرن الخدت فن مقت مجن هن الشارات: 


مرة أخرى كل ما سيتم وضعه هنا هو عن قواعد البيانات التي تساعد الجميع 
على الفهم وليس التطبيق والتقليد والمحاولة والخطأ. 


وعليه فبإمكان من يقرأ هذه الدروس أن يدل عليها الأخوة في الأقسام الأخرى 


مثل أوراكل وساي بيز وميكروسوفت أس كيو إل. 


تحیاتی›»› 


مرحباء»» 


من خبرة سابقة في تقديم المحاضرات في بعض المؤتمرات والمحافل الرسمية 
والدورات التدريبية... قد تفاجأً عزيزي القارىء من طلباتي التالية: 


إذا أردت إحتراف قواعد البيانات فعليك إتباع التالي: 


وآله حاسبة!! 
إقرأً الفاتحة وإبدأً بإسم الله الرحمن الرحيم. 


إذا راودتك نفسك أن تفتح الأكسس وتقوم بالتطبيق فلن تفهم شيئًا!! 
إذا راودتك نفسك أن تسأل أي سؤال يبدأ بكيف؟ فلن تفهم شيئًا!! 


في نظرية التعلم هناك سؤالين الأول كيف والآخر لماذا؟ 


كيف؟ سهلة جدا إعمل كذا وكذا ثم كذا وكذا !إهذا لا يصنع منك إلا مقلدا!! 
لماذا؟ تتطلب فكرا وعمقا وهدوءاء وهذا ما سنفعله في هذه السلسة من 
اشر رخات هو مخارلة الصال مهرد اا 


لماذا ننشاً هذا الجدول؟ لماذا بهذه الطريقة؟ لماذا الإستعلام وما هي أهميته؟ 
وهكذا 
ليس كيف ننشاً جدول بل لماذا نصع هذا الجدول عوضا عن ذاك!!! 


مرة أخرىء» لا حاسب» لا آکسس لا إس كيو إل» لا شيء» في هذه الدروس 
ستكون أنت الأكسس» أي انت من سيقوم بعمل الأكسس او ا6۵4 او أوراكل. 


إذا نجحت بتوفيق الله ان أجعل من تفكيرك وعقلك أن يقوم بعمل أي برنامج 
لقواعد البيانات بعدها سيكون كل ما هو مطلوب منك الإجابة على كيف أعمل 


هذا في الأكسس أو كيف أعمله في أوراكل وتصبح العملية في منتهى البساطة 
والسهولة والسلاسةء لماذا؟ 


لأنه عندها سيكون لديك كافة الأسس العلمية لقواعد البيانات. 


تحیاتی »۰۰ 


مرحباء»» 


قواعد البيانات !!! لاحظ كلمة البيانات» والبيانات هي مجموعة لا معنى لها 
من الأرقام والكلمات... البيانات أي شىء مثل كلمة" ربح "كلمة" خسارة "رقم 
"2000 "و هكذا... 


البيانات لا تعني شيئا هذه أول خاصية من كلمة بيانات أنها لا تعني أي شىء» 
والبيانات لا يستفاد منها إطلاقا!! 


الخاصية الثانية لكلمة بيانات هي الحجم» حيث أن البيانات دائما تعني الكثرة 
و الضخامة من خت العذةاا 


وهذا يضع كلمة بيانات في موقع سىء حيث أنها ضخمة وكثيرة ومتشعبة وفي 
نفس الوقت لا معنى لها. 


كلمة قاعدة تعني تنظيم الشىء على أسس» وهذا ما يتم في قواعد البيانات» هو 
تنظ اومن ثم ت ابا 1 أماذا؟ 


لماذا نقوم بتحليل وتنظيم البيانات؟ الإجابة هي... لتحويل البيانات إلى 
معلومات!!! 


ممهههمع 


من خلال معالجة البيانات تتحول إلى معلومات --- قاعدة أساسية في غاية 
الأهميةء الهدف إذا هو تحويل البيانات إلى معلومات. السؤال البديهي لماذا 
نقوم بهذه العملية؟ 


لسببين أساسيين: 


الأول: هو إتخاذ القرارات. 
الثائني: التخطيط 


قاغدة يانات تشمل فاد سكان المفلكة العريي السر دي كياات ل قمة ني 
ولكن عند معالجة البيانات وتحويلها إلى معلومات يصبح لدينا التالي مثلا: 


عدد الأطفال في تحت العشرة سنين %30 هي معلومة تتطلب التخطيط لبناء 
مدا 
رس 


مثال آخر أرباح السنة المالية الحالية %35 هنا لدينا معلومة نستطيع أن نتخذ 
عليها قرارا" إتخاذ القرارات "مثل توزيع راتب إضافي لمنسوبي الشركة. 


وھکل ا سے آنه بوب تحریل الیانات لے سل من المطرمات 
المتدفة للمساعدة على اتخاد القر ارات والتخطط 


سيكون مشروعنا هو بناء قاعدة بيانات لإدارة مستوصف -- مرة أخرى لا 
تندرې عزيزي القارىء --- لن نستخدم أي برنامج ولن نستخدم أي حاسب آلي 
من ام بااقطبى على الحاب اللي أن رم فبا ب ضقني 

الآن أطلب منك عزيزي القارىء مزيدا من التركيز... 


الطبقات الثلاث. 


حتى وإن كان ما سبق خطأ وهو تصميم قديم» لكني أطلب منك عزيزي 
القارىء آن تحفظها حتى لو كانت خطا" الطبقات الثلاثة" 


الطبقة الأولى۲ ٣|٥‏ ؟۲أ۴ 
وهي ما يسمى بالمقدمة أو واجهة انزunتخدمnterface| User‏ 


الطبقة الثانية ۲6 S607٩‏ 
وهي ما يسمى بطبقة المنطق والقو انين ع ه]١ |١6‏ اوها 


الطبقة الثالثة٣ ۲)٥‏ ۲|۲۹۵ 
وهي ما يسمی بالخلفية ٤٩۵‏ )عمج8 وهي طبفة ؟؟؟ قواعد البيانات!! 


لماذا از عجتك عزيزي القار ىء بهذه المصطلحات؟ 
لأسباب بسيطة وصغيرة جدا: 


قم بنسيان النماذج في الأكسس 
قم بنسيان التقارير في الاکریس 


النماذج والتقارير الموجودة في الآأكسس ليست للإحتراف وليست للبرامج 
الف او نراف ال ل 


لماذا هذه الزحمة؟؟؟ 

لأنه لا يوجد شيء في قواعد البيانات أسمه نماذج أو تقاريرء النماذج 
والتقارير تصنع في الطبقة الأولى وليس الثالثة. الطبقة الثالثة لقواعد البيانات 
بينما الطبقة الأولى هي للنماذج والتقارير. 

للمعلومية وقد يسعفنا الوقت لشرح المزيد لاحقا: 

Visual Basic .NE 1 مدخت~i‎ --- الطبقة الأولى‎ 

Visual C++ .Nenدختسن‎ --- الطبقة الثانية‎ 

Sybaseg Oracle yl Microsoft SQL pدختi‎ --- الطبقة الثالثة‎ 


لماذ| ا5س و MySQL sڪ Clipper s Dbase s FoxPro‏ 
يستخدمون الطبقات الثلاثة مع بعضها البعض في محتوى واحد؟ 


الإجابة هي لأن هذه التطبيقات للإستخدام الشخصي فقط !!! وليس لصناعة 
قواعد بيانات للسوق. إلا في حالات شاذة جدا مثل أن يكون عدد المستخدمين 
صغير أقل من 10 أشخاص فقط. 


لها ذا أردت أو تطمح للإختراف 

آخر هده المشاركة: 

هناك كلمتان في غاية الأهمية وقطعا تعرln Servers Client‏ 
قواعد البيانات دائما وأبداً على -- 66۲۷6۲ الطبقة الثالثة 


الواجهات والنماذج والتقارير دائما وأبدا على -- ها٥‏ الطبقة الأولى" يشذ 
عن هذا تطبيقات الإنترنت "وهذا موضوع آخر فيما بعد بمشيئة الله. 


المسافة بين أ" عأا© وال 56۲۷6۲ دائما غير معروفة»ء قد تكون 5 سم او 10 
آلاف كيلو متر› إنتبه هذه النقطة جيدا --- أعيد مرة أخرى المسافة بينهما غير 


تحیاتی›»› 


عند بداية تصميم أي قاعدة بيانات نبدأ بمعرفة أين يقع أ" أا© وأين 
يقع S6۲۷6‏ 


نجيب على الأسئلة التالية: 


ما أهمية التواجد المستمر ai1‏ اأج۸۷ !! إحفظ هذا المصطلح 
جيدا ويعني أن الطبقة الثالثة وهي طبقة قواعد البيانات -- كم يسمح 


لها أن کک Server‏ و ٠‏ م غ E‏ 
Ew‏ 

مستخدم البرنامج يجب أن يجيب على هذا السؤال؟ لأنه لو قال لك 
أريد الطبقة الثالثة أن تعمل على مدار السنة دون خروجها من الخدمة 
فهذا يتطلب أن يكون هناك مpں‏ )ھ8 خادم آخر یعمل عند سقوط 
الخادم الأساسي» وهذا يؤثر على كيفية بناء قاعدة البيانات. 


السوؤال الثاني هو القياس اهاه !! إحفظ هذا المصطلح جيداً 
ويعني کم شخصا سیستخدم قاعدة البیانات؟ کم شخصا سيستخدم 
قاعدة البيانات في نفس الوقت؟ كم عدد السجلات في قاعدة البيانات 
على مدى العشر سنوات قادمة؟ ما هو المطلوب عمله في البيانات 
القديمة هل تحذف أم تخزن؟ هل تخزن على نفس الخادم أم على خادم 
0۳ آخر؟ كيف يتبادل الخادمين المعلومات؟ وهكذا؟ هذا 
العنصر" القياس "هو الأهم على الإطلاق. 


عزیزي القارئ... 
عند تصميمك لأية قاعدة بيانات تخيل ما يلى: 


أن قاعدة البيانات فيها 5000 جدول 

أن كل جدول في قاعدة البيانات تحتوي على 10 ملايين سجل 
أنه يوجد 30 آلف مستخدم يتعاملون مع قاعدة البيانات في نفس 
الوقت 

أن المسافة بین 8٥۲۷٥۵۲‏ و 1٥ا٥‏ آلف كيلو متر 

لماذا هذا التخيل؟ 


لأنه هذا هو الطريق الصحيح لصناعة قاعدة بيانات قوية الأساسات 
وخالية من الأخطاء وستعلم لاحقا لماذا. 


من قرأ معنا حتى الآن ويرى أن قواعد البيانات شوية حقول على 
توليفة أستعلامات على نموذجين وكم تقرير أقترح عليه التوقف عن 
القراءة حيث لن يستفيد شيئا. 


لإنهاء قاعدة بيانات يحصل بها على ترقية أو يتفاخر بها مع اخوته 
وأصدقائهء وعليه تنتقل المفاهيم الخاطئة من شخص لآخر ببساطة 
ويصبح الآكسس" عفوا البرنامج التافه "هو قمة الإبداع والبرمجة. 


عفوا وعذرا لمحبي الآكسس -- كل ما أحاول عمله في البداية هو 
توضيح للمفاهيم ثم المصطلحات قبل أن نبدأً السباحة. 


أين الطبقة الثانية --- ۲16۲ ٥أوه]‏ دعك منها الآن 


كل تركيزنا حتى هذه اللحظة منصباً على الطبقة الثالثة وهي قواعد 
البيانات. 


آمل عزيزي القارئ أن تكون في هذه اللحظة قد جهزت براية ومحاية 
ودفتر ومسطرة وآلة حاسبة ومجموعة أقلام رصاص. 


إن لم تكن قد فعلت وتريد أن تكمل معنا من متطاق" القهلوة "و" الاد 
الجدع "على رأي الأخوة في مصر؛ أو منطلق سأفهم فيما بعد أو 
منطلق حلولي المشكلة التي بين يدي» أو منطلق سأجمع المشاركات 
ثم أقوم بدراستها وقراءتها فيما بعد --- صدقني لن تصل بقواعد 
البيانات إلا إلى طرق مسدودة وبعد عدة أشهر ستلغي الموضوع 
برمته. أو على أضعف الإحتمالات لن تبيع قاعدة بيانات واحدة على 
الإطلاق. 


الحاسب ال إطلاقا وهيا بنا نصمم قاعدة بیانات لإدارة مستو صف 


بالطرق العلمية الصحيحة. 


مرة أخرة يا أخوتي وأخواتي -- سنصمم یدویاً ولیس بإستخدام 
الحاسب الائ او الاکىس او غیره. 


تحیاتی»›»» 


مرحباء»» 


مسطرة 

خا 

براية 

الة حاسبة صغيرة 
دفتر کبیر 

أقلام رصاص 


ALN SL E E 
وسيبقى يلف ويدور ويسأل ويحاول ويخطىء وهكذا دواليك.‎ 


أمل ممن يستخدمون الآكسس الآن أن يوقفوه فوراً --- من سيطبق 
على الاكسس او آي برنامج غیره --- والله لن يستفید شیئا. 


الأسلوب العلمي لتصميم قواعد البيانات يبدا بتحديد شكل المخرجات 
او ما يعرف بإسم التقارير وعليه تكون التقارير هي أول خطوة 
يجتمع عليها فريق العمل مع صاحب المشروع للإتفاق على شكلها 


لاحظ عزيزي القارئ --- لا تصمم أبدا أبدا أبدا أبدا أي قاعدة بيانات 
قبل أن يكون لديك على أوراق عادية كل التقارير المطلوبة من 
المشروع. وحيث أن هذه الدروس لتعميق مفاهيم قواعد البيانات 
بشكلها العلمي الصحيح فسأضطر إلى مخالفة هذه القاعدة» ولكن 
سنعود آليها قريبا جدا عندما نطبق مشروعنا الثاني والذي ستقومون 
أنتم بعمله تحت إشرافي بمشيئة الله عز وجل. 


في الأسلوب العلمي الصحيح عند بناء قاعدة بيانات نبدأ بالتقارير تم 
نصمم الجداول ثم الإستعلامات ثم .... لن أقول لكم الآن حتى لا 
ا 


لغرض هذا الدرس الأول ولخبرتي في أفضل طرق إيصال المعلومة 
سأقوم بتوجيهكم خطوة خطوة بدأ بالجداول ثم الإستعلامات ثم 
التقارير --- أعلم أنه خطأ ولكن لأنه المثال الأول وأعلم أنه سيكون 
مفيدا بإذن الحق تبارك وتعالى. 


برنامج قاعدة بیانات لإدارة مستو صف 


لبناء الجداول نبداً بتحديد أقصى بعد لمكونات المشروع" في حالتنا 
يتکون من: 

أطباء 

عیادات 

مر 

في قواعد البيانات هناك الوظيفة الأساسية والوظائف الفرعية -- ما 


هي الوظيفة الأساسية للمستوصف ۔-۔ علاج المرضی' بإذن اللہ " 
وكذلك تحقيق أرباح 


إذا تم تعريف الوظيفة الأساسية للمشروع --- علاج المرضى -- 
بدون مرضى المشروع فاشل ولا معنى له --- إذا الجدول الأساسي 
هو جدول المرضى. 


افا که فاد کر د کین 
ماهي الوظائف الفرعية للمستوصف؟ 


هل يوجد مستوصف بدون صيانة؟ 

هل يوجد مستوصف بدون مقاول للنظافة؟ 

هل يوجد مستوصف بدون إدارة شؤون موظفين؟ 
هل یوجد مستوصف بدون صيدلية؟ 

هل یوجد مستوصف بدون جداول للنوبات؟ 

هل یوجد مستوصف بدون نظام حجز مواعید؟ 


واااو --- العملية بدأت" في الليمونة "على رأي أحبائنا في 


مصر 
العملية بدات تند 


لحظة -- توقف -- إتصل بصاحب المشروع -- صاحب المستوصف 
-- حدد اجتماع 


المشهد: فريق العمل معك أنت بصفتك قائد الفريق مع صاحب 
المستوصف مع مدرائه في غرفة الاجتماعات اأساعة العاشرة صباحا 
-- أمامك قنجان من القهوة" مو في رمضان طبعا" 

ما هو المطلوب من هذا الاجتماع؟؟؟ 


هل قاعدة البيانات المطلوبة هي للوظيفة الأساسية؟ آم للأساسية 


والفرعية أيضا؟ إذا تم دمج الفرعية؟ أي منها؟ 


لهذا السبب قواعد بيانات شوون الموظفين ذائعة الصيت لماذا؟ لأنها 
تصلح لكل منشأة وشركة بغض النظر عن نشاطها. وهكذا للمحاسبة 
والصادر والوارد وغيرها. 


ملاحظة: قد يسعفنا الوقت لاحقا وبتوفيق الله أن نشرح كيف نجعل 
مجمو عة من قواعد البيانات المختلفة أن تتحادث وتتخاطب بين 
بعضها البعض للحصول على تقارير موحدة منها جميعا وهو ما 


Distributed Database Application sS٣١—g 


توقف --- استمر --- لا بد من تحديد نطاق عمل قاعدة البيانات منذ 


اليوم الأولء يجب أن ينص العقد مع صاحب المشروع على نطاق 
قاعدة البيانات --- لماذا؟؟ 


هيا عاد لا بد أن تيجيب على السؤال !إفكر قبل أن تقرأ الإجابة 


السبب بسيط لأنه عند إكتمال قاعدة البيانات ومن ثم يتغير نطاق 
العمل تتغير الجداول تتغير العلاقات تتغير الإستعلامات تتغير 
التقارير --- مصيبة كبيرة وخسائر في الوقت والجهد.... إلا إذا كنت 
وحشا من وحوش قواعد البيانات لأنك يمكنك تصميم قاعدة البيانات 
بدون حقول .... واووووو ويقوم مستخدم القاعدة بعمل أية حقول 
كيف يشاء متى يشاء --- واااااووو --- ويستطيع أن يغير النمادذج 
او ا عه عمل کد فالخل حو اراو ووو ت کا 
هذا --- أسألوني فيما بعد عن هذا --- موضوع متقدم جدا جدا جدا ٠‏ 
لیس مکانه هنا. 


إنتھی الإجتماع وتم الاتفاق على أن تخدم قاعدة البيانات الوظيفة 
الأطباءء العيادات»› المرضى. 


فارغة في 1 اكتب"الجدول الرئيسي لوحف 
الحقول التالية. 


أريدك ا تنسى العبارات التالية: نص»› رقم» عملة» کكائن»› الخ 


أبدا معي بالكتابة في الصفحة التي ستحمل كافة حقول المشروع ولأن 
التطبيق يدوي فلن أكثر عليكم بالحقول سنزيدها عند التطبيق الفعلي 
على الأكسس لاحقا بمشيئة الله 


الحقول: 

رقم المريض -- 10 خانات 

إسم المريض -- 50 خانة 

جنسية المريض -- 25 خانة 

عمر المريض -- 2 خانة 

جنس المريض -- 1 خانة 

تشخيص المرض -- 350 خانة 
العلاج -- 350 خانة 

الف الف عة من امرض س وخا 
تاریخ دخول المريض -- 10 خانات 
وقت دخول المريض --- 5 خانات 
تاريخ خروج المريض --- 10 خانات 
وقت خروج المريض --- 5 خانات 


رقم الطبيب المعالج -- 10 خانات 
أسم الطبيب -- 50 خانة 
جنسية الطبيب -- 25 خانة 


راتب الطبيب الشهري -- 5 خانات 
بدل السكن للطبيب السنوي -- 5 خانات 
بدل النقل للطبيب الشهري -- 5 خانات 
جنس الطبيب -- 2 خانة 


رقم العيادة -- 10 خانات 

أسم العيادة -- 50- خانة 

رقم الجناح الذي تقع فيه العيادة -- 2 خانة 
راطا 2 اد 


ملاحظات -- 500 خانة 


E E e a 
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من نفذ ما سبق على ورقة بيضاء بخط واضح أن يفتح صفحة جديدة 
في الدفتر ويتقمص شخصية مدخل البيانات وبإستخدام المسطرة 
والقلم أن يرسم جدولاً فيه كافة الحقول السابقة كعناوين للأعمدة وأن 
يسجل 45 سجلاً لزيارات مرضى مع مراعاة ما يلي: 


أن يسجل على الأقل 3 إلى 5 زيارات لكل مريض 
أن يسجل على الأقل 3 إلى 5 علاجات لكل طبيب 
أن يسجل على الأقل 3 إلى 5 استخدامات لكل عيادة 


أن ينوع في أنواع الأمراض' ' كفانا الله وإياكم شرها" 
أن ينوع في جنس المرضى والأطباء 
ن ينوع في الجنسيات 


وهکذا... 


بعد أن تقوم بكتابة 45 سجلاً على الأقل نكون بحمد الله وفضله قد 
إنهينا تصميم قاعدة البيانات !!!!!!!!!!!!! طبعا لأإ!! 


سنقول لماذا في الدرس القادم بمشيئة الله. 


:٤ےتایحت‎ 


مرحباء»» 


لن نكمل مشروع قاعدة البيانات في هذا الدرس لإعطاء من يتابعوننا 
سنحتاجه فيما بعد بشكل كبير جدا والموضوع هو" مدخل البيانات." 


مدخل البيانات هو شخصية تتطلب من مصمم قاعدة البيانات أن 
يفهمها بشكل واضح» ولزيادة عنصر الشوق أقول لكم أنه يوجد 
obsل orig‏ Bوطبعا‏ هذه الدورات للأسف" كالعادة "لا تقدم في 
عالمنا العربي. 

الوظائف المملة sامل‏ 9و٣‏ آم8 هي وظائف" لا تستغرب عزيزي 
القارئ "ذات رواتب مرتفعة جدا جدا مع قلة الخبرة والتعليم المطلوب 
فيها !!! لماذا ؟ 


هذه الوظائف يترتب على الخطأً فيها خسائر جمة لصاحب العمل !!! 
بهذه البساطة. 


من أمثلة الوظائف المملة: 


فة الحافلات و الفافلات غل الخطر ظط البرنة الطوبلة ين الخرل 
وطبعا صديفنا --- مدخل البيانات 


اذا تعمقت في هذه الوظائف تجد أنه يترتب على الخلل فيها خسائر 
خسارة كبيرة. 


أو سائق شاحنة ينطلق من الرياض متوجها إلى الإمارات مثلا ومعه 
0 سيارات فارهة» يترتب على نومه حادث لا قدر الله ينتج عنه 
الكثير من الخسائر. 


وصديقنا مدخل البيانات -- تخيل أن يقوم بإدخال أرقام خاطئة عن 
المبيعات -- يترتب عليها تقارير توضح خسائر بينما الشركة تربح 
ی ا کک ی ا کک 
جداول بيانات خاطئة تعطى نتائج لا معنى لها. ليست مشكلة الحاسب 
الالي انه يعطيك نتيجة جمع 5 و 3 على أنها 8 وأنت تقصد جمع 4 
و 3!!! 


من رأى منكم مدخل بيانات فعليا سيضحك لما أقول» لأن مدخل 
قاعدة البيانات!!!! 


مدخل البيانات هو ذكر كان أو امرأة يبدأ يومه وعلى يمنه أو يساره 
تخو غ بح مرا مامات الوت انان اا اة عة 
البيانات» لأن الوظائف المملة يغلب عليها طابع التكرار ئممت | 
لنفس العمل ----- يبدأ مدخل البيانات بعد بضعة ساعات بالسرحان 
والتفكير بحياته ومواضيعه الشخصية والذي يدخل البيانات فعليا هو 
العقل الباطن الناتج من الخبرة!!! 


أنك كنت تفكر بموضوع ما ولا تتذكر الإشارات والانعطافات 
والشوارع... من كان يقود السيارة؟!!! 


أماذا هذا الموضع النفسي والفلسفي؟؟؟؟ 


لأنه مطلوب منك عند تصميم قاعدة البيانات ان تتقمص شخصية 
مدخل البيانات بين الحين والآخر» لماذا؟ لأنك تريد أن تحد بشكل 
كبير من حجم الأخطاء في قاعدة البيانات؟ لماذا نحد من أخطاء 
مدخل البيانات؟ لأن صاحب المشروع سيحصل على نتائج خاطئة 
وبالتالي لن يستخدم برنامجك؟ الخسارة تقع على كاهلك أنت|!!إ 


الهدف الآن واضح --- آمل ذلك --- عند تصميم قواعد البيانات لا 
نريد أن يقوم مدخل البيانات بإدخال بيانات خاطئة" القاعدة العلمية 
تقول --- هذا مس 


واااا١١١اااو‏ --- إذا كان مستحيلا فما العمل؟ الهدف أصبح أن تساعد 
مدخل البيانات على الحد من الأخطاء لا أن تمنعها كلياً!!! 


تتفق معي أن هذا غریب ۶ لماذا؟ لأنه من الناحية العلمية نستطيع 
أن نجبر مدخل البيانات على ألا يقوم بإدخال أي شيء خطا ومع ذلك 
القاعدة العلمية تنصح بعدم تنفيذ هذا بل فقط الحد من ذلك لا منعه !!! 
لماذا؟ لأن تكلفة المنع في تصميم قواعد البيانات عالية جدا وتفوق 
تكلفة عمل تدريب صغير لمدخل البيانات. 


لماذا نحد من الأخطاء الناتجة عن إدخال البيانات أصبح واضحا" آمل 
الآن. 


الحاسب الال" متخلف "عفوا --- الحاسب الال یعکس فکریا ریاضیا 


المنطق هو إدراك عالي جدا لا يصله إلا البشر فقط!! 


أقرأ معي الكلمات التالية فضلا منك: 


ماذا قرأت ؟؟؟ 
لأنك" بشر "ولديك الإدراك الذي فضلك به الحق تبارك وتعالي فإانك 
e‏ 


توقف - رکز -- استمر 


في مطلق برامج قواعد البيانات (كلها على الإطلاق) ومن ضمنها 
الآکسس ما سبق يعني 6 كلمات مختافة ؟؟؟؟!!!! 


فلو کان لدبك استعلام ترید ډه أ تحصل بام إجمالي أ عداد الإناث 
في قاعدة البيانات فانك قطعا لن تحصل غل إجابة صحيحة ؟؟؟؟!!| 


الآن نفكر ونخطط لقاعدة البيانات --- كيف نمنع مدخل البيانات من 


إدخال حقل الجنس للإناث بطرق مختلفة؟ 


بل ليس هذا فقط؟؟؟ المطلوب منك كمصمم قواعد بيانات هو أكبر من 
هذاء المطلوب يتجاوز الحد من أخطاء مدخل البيانات إلى مسافة أبعد 
وهي المساعدة على إدخال البيانات. 


طبعا لا أقصد المساعدة اليدوية في إدخال البيانات !!! بل في طريقة 

تصميم القاعدة لتساعده على ذلك وعندها قد تسمع ان مدخلي البيانات 
يدعون لك" وان كنت أشك في هذا لكونهم دائمي التذمر بغض النظر 
عما تعمله."!! 


إحفظ الكلمة التالية" المصطلح ۷أ 9 |٣]‏ "ويعني التكامل والتماسك» 
قاعدة الائات مثل ما فرحا ساقًا هی يانات لا قمة لها" بعد 
تحليلها تصبح معلومات "والبيانات بطبعها عدم التماسك والتكامل 
ومن هنا لا بد الا تترك أي تغرات في قاعدة البيانات يتسلل منها 
مدخل البيانات إلى إدخال بيانات خاطئة تؤدي إلى فقد التكامل 
والتماسك لبنية قاعدة البيانات. 


n'y‏ اتعني أن كافة حقول وسجلات كافة الجداول تعمل مع 
بعضها البعض بشكل متناغم وبشكل يحد من أخطاء إدخال البيانات . 
بعد کم درس أسأل عن |٣6 9٣١۷‏ وخلي واحد ما يجاوب صح» 
الكامل واماد 

الآن عزيزي القارئ» أعد قراءة هذه الصفحة وباستخدام قلم 
الرصاص أكتب المصطلحات وأشرحها لنفسك مرة أخرىء» ليتنا 
نكتب متلما نقرأ. الكتابة هي المعلم الأول. 


أية أسئلة تقفز إلى آذهانكم --- أسألوها حتى يطمئن قلبي أننا نسير 
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بالاتجاه الصحيح. 

للحد من أخطاء إدخال البيانات نقوم بعمليات: 
المنع 

الاختيار 

تحديد النطاق 

الإكمال والإدخال والاختيار الآلي 

التأكد من اأ وما |٣‏ لقاعدة البيانات 


وكلها سنتحدث عنها فيما بعد بإذن الحق تبارك وتعالى. 


تحیاتی»»» 


مرحباء»» 


I 
بسلك.‎ 


آمل آنه يو جد هناك الآن في هده الليلة المباركة من قام فعلا بتصميم 
الجدول الأساسي لفاعدة البيانات الخاصة بالمستو صف ڪلم ورقة 
بيضا 

۶ » 


آمل انه يوجد هناك من قام بإدخال 45 سجلا في قاعدة البيانات (على 
الورق) من خلال جدول رسمه بالمسطرة والقلم. 


آمل أننا نعمل سويا بهدوء وروية وتفكير وقناعة لهدف الوصول من 
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م کل( سارن و الشات ف درل 
على ورقة بيضاء فرجاء لا يكمل القراءة. توقف فورا الآن. رجاء لا 
تضيع جهدي ووقتي سدی. توقف ومن تم تابع بعدما تکون انهیت 
المطلوب منك. 


صدق أو لا تصدق أن ما قمت بعمله هو قاعدة بيانات مكتملة من 
كافة الجهات 

صدقٰ E SS Sa‏ 
تصمم به قواعد البيانات قبل عام 1969 ميلادية ٠‏ 


كل ما عليك أن تفعله الآن هو أن تستمع (مع فنجان من القهوة) 
و الى الجدول الجميل د as‏ والذي و 


بيانات. 


تح صفحة بيضاء جديدة وفي منتصف الصفحة" الأة' اومن تم 
أنقل معي هذه الأسئلة إلى الورقة: 


كم عدد الزيارات للمستوصف؟ 


كم إنثى قامت بزيارة المستوصف ودفعت أكثر من 100 ربإل؟ 
كم طبيبا في المستوصف لا ينتمي إلى الجنسية البريطانية؟ 
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كم زيارة حدثت بعد منتصف الليل؟ 

ما هو متوسط التكلفة المدفوعة من قبل الذكور؟ 

وا الشهري لبدل النقل للطبيبات؟ 

 ؟ايرهش‎ 

فاا هو اا کل ال مه هنا ا 

ا أا افر 

كم طبيبة اسمها سميرة؟ 

كم عدد العيادات في الطابق التالث؟ 

كم عدد الزيارات من قبل المرضى الصباحية؟ 

كم عدد الطبيبات السعوديات اللاتي دخلهن السنوي أكثر من 150 
الف ربإال؟ 

كم طبيبا تواجد في عيادة في الطابق الأول وكان معه مريضا ذكرا؟ 
ما هو الدخل اليومي للمستوصف؟ 


صدقوني -- هذه قاعدة بيانات كاملة من الألف إلى الياء 


آمل الآن من الجميع وبدون عمل أي تعديل على بيانات الجدول الذي 
أدخلتم به السجلات (على الأقل 45 سجل) أن يجيبوا على الأسئلة 
السابقة ويقوموا بكتابة الإجابات في النصف الأسفل من صفحة 
الأسئلة. 


صدق أو لا تصدق --- راقب كيف يتولد الإحباط والصداع وأنت تعد 
وتحاول الإجابة 

صدق أو لا تصدق --- أن ما تقوم به الآن هو تقريبا وإلى حد كبير 
هو ما يقوم به أي برنامج قواعد بيانات -- أنت الآن تقوم بدور 
رگش 


مر اکر عندما نصل إلى القواعد والمفاهيم الأساسية لبناء نظم 
قواعد البيانات وأنت تقوم بالقراءة فقط دون تطبيق أو تقوم بالتطبيق 
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على الآكسس أو غيره -- صدقني ستعود إلى نفس ما كنت عليه قبل 
أن قرا هذه المراضبم وان ذلك سرى تف افر اء كت ترا 
فقط فأنت تضيع وقتك. 


قم بتشذيب أقلام اارصاص 

لدينا الكثير والكثير والكثير من الكتابة. 

الله المستعان. 

ٹحاتی؛»» 

مرحباء»» 

من نفذ التمرين الأول (كتابة على الورق) يمكنه الآن الإستمرار معنا. 


ان ا تمت شه هر تاع مات صحيحة مك الخ ت وط ر اة 
التصميم هذه تسمى ءعءجطهاه0 ها۴ أو قواعد البيانات المسطحة 
وهي نفس الطريقة المتبعة في لغة C0801‏ ولا أعلم إن كانت 
00801 مازالت تتبع نفس الأسلوب حيث تركت هذه اللغة مذذ 
أكثر من 10 أعوام. 


عند وضع كافة الحقول بدون أي إستثناء في جدول واحد نحصل على 
(قاعدة بيانات مسطحة) -- لا تستغرب أن أقول للك ت EXCEL‏ 
يوجد فيه تطبيقات متقدمة لقواعد البيانات من النوع المسطح. 


هناك ميزة كبيرة ومهمة جداً لقواعد البيانات المسطحةء وهذه الميزة 
هي أن تصميم وإنشاء وتنفيذ قاعدة البيانات يتم في وقت قصير جدا 


۳ قياسيء قاعدة البيانات التي قمنا بتصميمها لإدارة المستو س 
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دقائق. هذه ميزة رائعة جدا. 


نخفظ ويا قراغ المانات من النرع المسطح ةع هي عبار عن 
وتصميم قاعدة البيانات. 


من اهن التطبيقات على قواعد البيانات المسطحة هي التطبيقات التي 
يراد منها عمل الإحصائيات فقط. لن أسهب في شرح هذا النوع من 
قواعد البيانات لأن إستخداماته محدودة جدا جدا وفى إطار ضيق» 
وبعد أن نستوعب النوع الثاني من قواعد البيانات ستكون الأمور 
أوضح بمشئية الله عز وجل. 


سؤال: بماذا تتميز قواعد البيانات من النوعأجا٣‏ ؟ 
سؤال: ما هي قواعد البيانات من النو عأج|۴ ؟ 


نعود إلى المستوصف» نحن الاآن في قاعة إستقبال المرضى في 
ال کن 


يدخل المستوصف مريض: 
العمر: 42 عاما 

الإسم: محمد عبد الله 
الجنسية: سعودي 

الجنس: ذكر 

المرض: رانا 


نطلب منه كافة المعلومات تم نقوم بتحويله إلى: 
الطبيب: سميرة عبد الخالق 


الجنس٠‏ أنثى 
العمر: 52 
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الجنسية: مصري 


5 


ونقوم بتوجيه المريض إلى الطابق الثاني حيث تقع عيادة الأنف 


والأذن والحنجرة. 


عند خرو ج المريض نقوم بتسجيل تاريخ ووقت الخروج والتكلفة 
المدفو عة منه. 


ما الذي حدث؟ 
تم اضافة سجل جدید في قاعدة البيانات المسطحة التي قمنا بانشائها. 


خرج محمد عبد الله من المستوصف وفي عجلة من أمره صدمته 
سيارة مسببة كسر في الساق اليمنى... 


دخل محمد عبد الله مرة أخرى إلى المستوصف وتم توجيهه إلى 


ما الذي حدث؟ --- قمنا بإاضافة سجل جديد في قاعدة البيانات 
الخاصة بالمستوصف 


لدی خروج محمد عبد الله وذهابه إلى البيت قدمت له زوجته عشاء 
أتعب معدته فنقل بسيارة الإسعاف إلى المستوصف مرة ثالثة. 


دخل محمد عبد الله (المسكين) إلى المستوصف مقدما بيانته السابقة 
مرة أخرى وتم تحويله إلى عيادة الأمراض الباطنية. 


ما الذي حدث؟ قمنا بإضافة سجل جديد إلى قاعدة بيانات 
المستوصف. 


26 


لنترك المسكين محمد عبد الله قليلا ونذدهب إلى صديقنا مدخل البيانات 
في قاعة الإستقبال ونسأله عما فعل الليلة. 


کے هذه الليلة قام مدخل البيانات بادخال ثلانة سجلات» بماذا تمیزت 
هذه السجلات؟ 


تميزت بأن أحد عناصر قاعدة البيانات وهو (المريض) قد تكرر 
تسجڊا » بیاناته ثلاث مرات 


ماذا يعني هذا؟ 


أنه عند تكرار دخول المريض للمستوصف أكثر من مرة يتطلب 
الأمر في كل مرة إدخال كافة بياناته كاملة. 


أنه عند تكرار إستخدام الطبيب (متل أن يدخل خمسة مرضى على 
طبيب العظام) يتطلب الأمر إعادة إدخال بيانات الطبيب مرة أخرى. 


أنه عند تكرار إستخدام أي عيادة (مثلا عشرة مرضى تم علاجهم من 
قبل ثلاثة أطباء كلهم في العيادة الباطنية) يتطلب الأمر إعادة إدخال 
كافة بيانات العيادة. 


في قواعد البيانات المسطحة يتم إعادة إدخال بيانات أي عنصر يتكرر 
اكثر من مرة. 
الآن سأذهب لشرب فنجان من القهوة وأتمتع بقليلا من التمر... 


وعندما أعود بعد بضعة دقائق أتمنى من الجميع أن يكونوا قد فكروا 
في إجابة السؤال التالي. 
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ما هي المشكلة من تكرار إدخال البيانات؟ 


تحیاتی»›»» 


مرحباء»» 

توقفنا عند السؤال التالي: 

ما هي المشكلة من تكرار إدخال البيانات؟ 
الجواب: مشاكل جمة لا عد ولا حصر لهاإ!!! 
أهم هذه المشاكل: 


نکر ار انات کو دة اض 

إستنزاف شديد للسعات التخزينية متل الأقراص الصلبة 

موطن خطير لإرتكاب الأخطاء الناتج عن التكرار فمتلا المسكين 
محمد عبد الله في الزيارة الثانية تم تسجيل إسمه على شكل (محمد 
عبدالله) بدون مسافة بين التعبيد ولفظ الجلاله وبهذا يصبح لدينا 
مریضا جدید!!! 

أما المشكلة الأكبر هى عند إضافة حقل جديد لقاعدة البيانات» متلا 
إضافة تاريخ الميلاد للمريض !!! يتطلب الأمر الآن إدخال نفس 
التاريخ في كافة السجلات فإذا كان لدينا 500 زيارة منها 42 زيارة 
للأخ محمد عبد الله يتطلب الأمر إعادة إدخال تاريخ الميلاد 45 مرة 
!! 


تكرار ادخال البيانات هو أحد مصائب ولیس مشاكل قواعد البيانات 
المسطحة وكانت مرتعا خصبا للأبحاث في قبل عام 1970 ميلادية. 
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العالم الخطير السيد 6055 والذي يعمل في شركة 8| قام في 
عام 1969 ميلادية بطرح أول نظرية تقوم بعلاج مشاكل قواعد 
البيانات المسطحة |۴ وتم تسميتها قواعد البيانات العلاقية 
Relational Databases‏ 


صدق أو لا تصدق» مازالت هذه النظرية هي المعمول بها في كافة 
برامج قواعد البيانات الموجودة في العالم الان وطبعا من ضمنها 
الآكسس. 


نظرية هذا العالم تتكون من 12 قانون كل واحد من هذه القوانين 
يتطلب محاضرة خاصة»› أي نحن بحاجة إلى 12 محاضرة على 
الأقل لشرح هذه القوانين»› ولكن لضغط الوقت ولعدم رغبتي في 
الإسهاب في الجزء النظري بل أرید أن رکز على التطبيق العلمي 
الأسس العلمية لقواعد البيانات. 


إن القوانين التي وضعها هذا العالم (الذكي جدا طبعا) تم تبنيها من 
قبل الشركات العالمية وبدأت تنتج برامج تعتمد على هذه القوانين 
وتتيح هذه البرامج لمستخدميها بتصميم قواعد بيانات علاقية 

ا2 Relation‏ ولصعوبة هذه القوانين يكفي أن تعلم عزيزي القارىء 
أن أفضل قاعدة بيانات تم تصميمها في العالم إلتزمت ب 8 قوانين 
فقط من 12 الأصلية!!! 


ای ن اتطرر ق رات داد انیاتات م رر اکل و اکس 
CODD.‏ 


قبل الخوض في قواعد البيانات من النوع العلاقي اج 0ااجامR‏ 
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نقول التالي: 


أن قواعد البيانات من النوع اج ههام8 تقول بحل كافة مشاكل 
قواعد البيانات المسطحة بل تؤدي إلى) |٣69٣‏ مين يذكر هذا 
البيانات. 


ولكن الثمن المقابل لهذا الميزات غير رخيص!!!! 
فقواعد البيانات من النوع العلاقي: 


لا يمكن إنجازها من قبل شخص واحد مثل تلك المعمولة بالنوع 
المسطح» هذه تحتاج إلى فريق عمل. 

أك إنشاء قواعد البيانات وتصميمها بالشكل العلاقي اعت بعدة 
مراحل من النوع المسطح وتتطلب تخطيطا وفكرا وإستراتيجية 
واضحة. 

أن التكلفة المدفوعة في تصميم وبناء قواعد بيانات علاقية أكبر بكثير 
من تلك المدفوعة في المسطحة»ء ولكن الثمن يتم تعويضه من خلال 
اختزال تكلفة الصيانة والتطوير لفاعدة البيانات. 


لا يوجد نوع آخر لقواعد البيانات في العالم غير هذين النوعين: 
مسطح |۴ ذي تكلفة منخفضة في التصميم وتكلفة مرتفعة في 
الصيانة والتطوير ويعاب عليه تكرار البيانات التي تؤدي إلى رفع 
تكلفة التخزين وبطىیء البحث والإسترجاع والإستعلام وغيره. 
علاقي Relational‏ ذي تكلفة مرتفعة کی التصميم وتكلفة منخفضة 


الصيانة وال يعاب عليه ية الت التى تحتاج |١‏ 
في و ير وډ صعوڊ ج 
فر مل ولگ ندل کن کل ایا ف ات :اة 
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تحیاتی›۰»› 


مرحباء»» 
اذا كنت تريد عمل قاعدة بيانات: 


أنت المصمم لها 

أنت المستخدم لها 

أنت مدخل البيانات 

أنت من سيقوم بعمل إحصائيات وتقارير سريعة 
انت تحت ضغط الوقت والتكلفة 


مسطح .۴|۵1 لا تنس آنه لا يوجد فروق إطلاقا بين البرامج كل ما 
نتعلمه هنا ینطبق علی: 


Access 

FoxPro 

Dbase 

Clipper 

Microsoft SQL Server 
Oracle 


کا مكف اک فاع مادا م کے غ ع شر 
أن يكون عدد السجلات صغير نسبيا مثل عدة آلآف. 


آما... 
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إذا كان مدخل البيانات يختلف عنك بصفتك مصمم لقاعدة البيانات 
أو أن القاعدة ستستخدم من قبل آخرين -- تريد بيعها في السوق متلا 
أو ربطها بموقع على الإنترنت 

أو أن لديك متسع من الوقت 

أو لديك فريق عمل 


أو ريد أن تصمم القاعدة وفق الاسسن العلمية والصحيحة لقواعد 
البيانات فيجب أن تقوم بالتصميم على أسلوب اج ههام8 العلاقي 
وبتطبيق قو انين السيد0 ©٥005‏ 


ماذا يقول مستر 50 °00 وسنبسط هنا (من يريد القوانين الفعلية 
يطلبها لإرسالها له ولكنها بالأسف باللغة الإنجليزية وتتطلب إحترافا 
في الإنجليزية وفي قواعد البيانات لترجمتها) أرغب ممن سيطلبونها 
ألا يقزموا بترجمتها حتى لا يوقعوا من يقرأها باللغة العربية في 


قلنا أننا سنبسط قوانين مستر C000‏ والتبسيط له قوانين أيضا حيث 
أرغب ممن يقرأ ألا يقوم بالعد للحصول على 12 قانون لأننا قد 
نبسط قانونا واحد بقوانين متعددة أبسط وأسهل. 


قبل الدخول في قوانین مستر C0050‏ سأطرح قوانين مستر 
aster‏ nternetM|اء‏ بالمناسبة هذا هو محدٹکہ!!! 


لا تستخدم اللغة العربية في كل مما يلي. 
اسم قاعدة البيانات 

أسماء الجداول 

انقاء الحقول داخل الجداول 
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عند التسمية لكل ما سبق إستخدم الأحرف اللاتينية (اللغة الإنجليزية) 
والآن ركز معي بشدة --- لا تضع مسافات بين أي إسم لكل ما سبق 
جدول الأطباء عاط آءإهامم لاحظ أن الحرف الأول من كل 


طبعا إتفقنا على أنه لا يوجد شيء یسمی نماذج وتقارير ومایكرو 
وغیره (مثل ما في الأكسس) هده تبسیطات للاستخدامات المحدودة 
جدا والتي لا ترقى إلى التطبيقات التي يتطلبها السوق !!! وعليه 
سننسى أنه يوجد نماذج وتقارير وما إلى ذلك من السخافات لأنها 
مضيعة للوقت والجهد ولن تصنع منك لا مبرمجا ولا مصمما لقواعد 
البيانات 


کل ما لدینا (حسب ما قلناه سابقا) جداول وإستعلامات فقط (حتی 
تاريخه طبعا) وهي كلها موجودة في الطبقة الثالثة (من يتذكر الطبقة 
التالتة؟) وأين توجد؟ 


انتهت قوانيني !! لنعود إلى مستر 0000© 

ما هي قوانینه؟ 

كل وحدة متماثلة من وحدات قاعدة البيانات توضع في جدول مستقل 
بذاته يعبر عن محتويات هذا الجدول. مثال جدول المرضي لا يحتوي 
أية بيانات إلا عن المرض فقط وهو وحدة مستقلة بذاتها. ينطبق نفس 
الو غل اب خداول اخرى: 

في الجدول الواحد لا يسمح بأي تكرار للسجلات» بمعنى أنه عند 


إدخال معلومات طبيب متلا في جدول الأطباء يمنع تكرار بيانات هذا 
الطبيب مرة أخرى. 
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لا بد من تمييز كل سجل في الجدول بحقل مميز (ويفضل أن يكون 
حقلا واحدا فقط) ويسمى مفتاح الجدول. في الآكسس مثلا يسمى 
Primary Key‏ 


بيانات حقل المفتاح الرئيسي لا تتكرر لأي سجل. أي أن كل سجل 
يحتوى على بيانات مختلفة في المفتاح الرئيسي أو الأساسي سمه ما 


نللا , 


لا يسمح لبيانات حقل المفتاح الرئيسي أن تكون فارغة أو غير 
ERY‏ 


نستكمل بعد فنجان من القهوة. 
تحیاتی»›»»› 
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مرحباء»» 


أعتذر لطول فنجان القهوة لإستقبالي بعض الضيوف» وحقيقة يبدو أن 
الضف تهر باي اهم فى عاك خر "ق اعد الات "رها الد من 
عالما!! 


ما زلنا نبحر مع السيد C050‏ في قوانينه الخاصة بقواعد البيانات 
العلاقية: 


نفتح في الدفتر صفحة جديدة ونبري قلم رصاص وتعالوا بنا نعيد 
تصميم قاعدة البيانات خطوة خطوة ة (على الورق طبعا) مع إعتبار 
لقو انين العالم9 °05 


لدينا فى مشروعنا الخاص بادارة مستوصف ثلاثة عناصر مختلفة 
وحسب القوانين لا بد لكل عنصر أن ينفرد بجدوله الخاص وعليه 
ومن الوهلة الأولى سنقوم بتصميم ثلاثة جداول مختلفة واحد 
للمرضى والثاني للأطباء والثالث للعيادات. 


أريدك عزيزي القارئ الآن أن تركز معي بشدة: 
تخيل أن كل جدول من الجداول الثلاثة يحتوي على 500 حقل!! 


إتفقنا؟ هذا التخيل في غاية الأهمية حتى نفهم أول القوانين والأسس» 
لماذا نتخيل هذا؟ 

لسبب بسیط جدا (سنستوعبه بشکل اکبر فیما بعد) وهو أن عدد 
الحقول في أي جدول لا قيمة له حالياً !!! لماذا ليس له قيمة حاليا؟ 
لأننا في قواعد البيانات العلاقية لا نهتم لوصف الجدول بل نهتم 
نالدزجة الأول ونر كز على تماسكقاعدة البافات .من يتذكز 


lلnصطntegrityzİ|‏ ؟ 


إذا الهدف هو تماسك وصحة بناء القاعدة وليس وصفها وتصميمها 
حالیاء وبناء عليه أطلب مناك عزيزي القارىء الآن أن تغمض عينیك 
-- خذ نفسا عمیقا -- زفیر ر -- إفتح عينيك بهدوء وتخيل معي ثلاثة 
جداول أساسية كل دول يصف جزئية واحدة محددة وكل جدول 


يحتوي على 500 حقل. 
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إتفقنا؟ 


مرحباء»» 


الآن صفحة جديدة بيضاء (في الدفتر) -- في منتصف الصفحة -- 
قاعدة بيانات الآباء والأبناء. 


دعك من المستو صف الآن. 

تريد ان تنشاً قاعدة بيانات توضح الأباء والأبناء في عائلتك. حسب 
قوانین 0K00‏ لدینا جدولین وکل جدول فيه مفتاح رئيسي. 

دعنا نتفق... 


عندما قول برامج قواعد بیانات فأنا أقصد آكىس و ا8۵وأوراكل 
وغيرها 

عندما أقول قاعدة بيانات فأنا أقصد تلك التي تقوم أنت بتصميمها 
باستخدامك لأي من البرامج المشار إليها أعلاه. 


من يجيبني على السؤال التالي: هل قوانين 6K050‏ للبرامج أم 
للقواعد؟ ب بمعنى آخر هل هي لشركة ميكروسوفت حتى تعطينا برنامج 
آکسس جید ام هده القوانين لك أنت عند تصميمك لقاعدة البيانات؟ 


ماذا يعني هذا؟ ببساطة وركز معي بشدة أنك عندما تضع حقلا أساسيا 
O Ty‏ 
ا 


لدينا في هذا التمرين جدولين واحد للأباء والآخر للأبناء: 
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جدول الآباء 


رقم الأب -- حقل رئيسي 
إسم الأب 
عمر الأب 


جدول الأبناء: 

رقم الإبن -- حقل رئيسي 
إسم الإبن 

عمر الإبن 


الآن في صفحة جديدة إرسم جدولا بالمسطرة وقلم الرصاص (رجاء 
للمرة المليون على الورق) حتى نفهم سوياء وسمه جدول الاباء 
وأدخل البيانات التالية وهي مرتبة رقم الأب إسم الأب عمر الأب 
2 خالد سعید أحمد 32 

7سمير حسين الأحمدي 63 

1ءمحمد أحمد عبد القادر 36 
أجب عن الاستاة التالية: 


81سمير حسين الأحمدي 63 --- ماذا يحدث؟ 


من لم يعرف الإجابة أقترح عليه أن يبدا مرحلة إعادة القراءة مرة 
اخری بترکیز اعلی 


نجيب فيما بعد بإذن الحق تبارك وتعالى. 


تحیاتی»»»› 
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مرحباء»» 


ماذا يحدث عند إضافة سجل جديد في جدول الأباء بالبيانات التالية: 
871سمير حسين الأحمدي 63 --- ماذا يحدث؟ لن يحدث شيا 

سجل جديد لا غبار عليه حتى وإن تشابه الإسم (وهو خطأ أيضا) 

لكنه غير مهم حاليا -- لا تنس الهدف وهو تماسك قاعدة البيانات. 


1سامي مطلق الدوسري 51 -- ماذا يحدث؟ هذا يخالف أحد 
قوانين مخترع قواعد البيانات العلاقية السيد C05‏ والذي ينص 
على منع بل إستحالة تكرار المفتاح الأساسي لأكثر من سجل واحد. 
السؤال البديهي لماذا يمنع من تكرار 901 في سجلين مختلفين؟ أو 
بعبارة أخرى» لماذا لا نستطيع تكرار بيانات المفتاح الأساسي؟ والآن 
نبداً في التركيز مرة أخرى. ملاحظة -- إذا وجدت برنامج قاعدة 
بیانات (وان شاک في هذا) يسمح ل SOE‏ هذا ا 

برامج اغ البيانات ا صلة» لكن اذا استخدمت ا قدیما 

صمم قبل 1970 ميلادية فقطعا سيسمح لك لأن كل برامج قواعد 
البيانات قبل هذا التاريخ کانت. |۴ 


يستكمل معي ذووي الأقلام والبريات والذين كتبوا فقط!!! 


صحيح أن K0 5D‏ نظم لنا قاعدة البيانات من خلال فصل الوحدات 
الأساسية في جداول مختلفة ولكنه خلق لنا مشاكل جمة لتصميم 
القاعدة» تذكرون طبعاً أن تصميم قواعد البيانات العلاقية أصعب 
وأعقد من تلك المسطحة.†م|۴ 


ما هو الهدف من قاعدة بيانات الآباء والأبناء؟ 

هو الحصول على تقرير أساسي يتم فيه سرد الأبناء لكل أب نختاره 
فمثلا عند إختيار سامي مطلق الدوسري من قاعدة البيانات تقوم 
القاعدة بسرد كل الأبناء اللذين يقولون لسامي (بابا.( 
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من يشعر معي أنه يوجد هناك مشكلة الآن؟ حيث أن كافة الأبناء 
موجودون في جدول مختلف . ... ممممممممممم --- من هنا جاءعت 
كلمة قواعد البيانات العلاقيةت أن كك غادفة مان الكاول و هدا 
قانون من قو انین. 0005© 


مختلف لا بد من الوصول لهذه البيانات عن طريق علاقة ما. 


كلام كبير» ما يعني؟ للحصول على الأبناء التابعين لأب ما يتطلب 
الأمر إنشاء (علاقة) بين الجدولين. 


في جدول الاباء الحقول التالية: 
رقم الأب -- حقل رئيسي 

إسم الأب 

عمر الأب 


وفي جدولالأبناء يوجد الحقول التالية: 
رقم الإبن -- حقل رئيسي 

إسم الإبن 

عمر الإبن 


لنفترض أنه يوجد في جدول الأبناء 8 سجلات» كيف نعرف أن 
السجل الثالث هو أحد أبناء خالد سعيد أحمد الموجود في سجل 
الآباء؟؟ 


نعود ونسأل مستر 6K00‏ » بعد تفكير عميق وبضعة فناجين من 
القهوة يرد علينا هذا العالم ويقول لنا EEA‏ 
ركززززززززززززززززززززززززززززز --- إستخدم (الحقل 


الغريب)؟؟؟ 
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سأسألكم عن ما هو الحقل الغريب فيما بعدء فلنركز جيدا ولنستغل 
الدفتر الذي أمامنا وأقلام الرصاص للكتابة والتركيز -- لا تنسوا أن 
الهدف تماسك قاعدة البيانات وليس الحقول والإستعلامات» نحن في 


مرحلة مبكرة من التصميم. 
ممممممممح 


Foreign Field الحقل انلغريب‎ 


ماهو ؟ 
اة 
الجدول؟ 


لا يمكن أن يكون مفتاحا رئيسيا في الجدول الذي ينشأ فيه 
يجب أن يوجد ما يشابهه في جدول آخر 

يجب أن يكون مشابها ومطابقا ونسخة مقلدة بالضبط من الحقل 
الأساسي في الجدول الآخر 


واااو صداع.... تعالوا نبسط هذه الجمل أكثر وبروية وبهداوة ومع 
فجن هره و بالا ولس افر ا2 


أين المشكلة هل هي في جدول الآباء أم في جدول الأبناء؟ 
الإستنتاج المنطقي أنها في جدول الأبناء لماذا؟ 

لأن جدول الأبناء يسمى جدولا غير مستقر لماذا؟ لآنه يحتوي على 
بيلنات متماسكة وغير منتميةء ماذا يعني هذا؟ لنفكر قليلا. 


في جدول الأبناء 8 سجلات» إذا نظرنا إلى هذا الجدول نرى أنه 


متماسك ومتناغم ولکن تکمن مشکلته في انه لا یدلنا على من أب هذا 
وأب هذا. 


40 


طالما أن المشكلة في جدول الأبناء إذا الحقل الغريب يجب أن يكون 
في جدول الأبناء؟ 


من لم يستطع أن يستنج هذا معنا (أن الحقل الغريب يجب أن يكون 
في جدول الابناء) فاقول له لا تغضب.. ماشي» سنعید شرح هذه 
الجزئية بعد قليل مرة أخرى من زاوية مختلفة. 


لنستكمل... الحقل الغريب يجب أن ينشاً في جدول الأبناءء ويجب ألا 
يكون مفتاحا رئيسياًء هذه نقطة في غاية الأهمية لشخصية الحقل 
الغريب. إذا رقم الإبن لا يصلح» وحقيقة القول لا تضيع وقتك في 
البحث عن الحقل الغريب في جدول الأبناء لأنه لو كان هذا الحقل هو 
مناج الحقول الموجودة فعلا في جدول الأبناء لما صار غريبا» 
ونحن نبحث عن حقل غريب أي لا يمت لجدول الابناء باي صلة. 


من أين نأتي بهذا الحقل الغريب؟ الجواب هو أن الحقل الغريب 
موجود دائما وأبدا کي الجدول الذي تريد أن تنشاً معه العلاقة. 


لنعد إلى مشكلتنا وهي كيفية تحديد الأبناء الذين ينتمون إلى أب واحدء 
نحن نبحث عن الأخوة والأخوات. إذا نريد من جدول الأباء حقلا 
الأبناء ويساعدنا على إتمام إنشاء العلاقة. 

هذا الحقل هو رقم الأب من جدول الآباء. 

عند إستلاف رقم الأب من جدول الآباء ووضعه كنسخة مطابقة في 
جدول الأبناء» يصبح هذا الحقل أساسيا في جدول الآباء وغريبا في 
جدول الأبناء. 


41 


أصبح جدول الأبناء كما لی 
رقم الإبن -- حقل رئيسي 
إسم الإبن 

عمر الإبن 

رقم الأب 


لنعد إلى شروط مستر K0 5D‏ الحقل الغريب يجب أن يكون مطايقا 
ونسخة مشابهة لتلك الموجودة في الجدول الأساسيء أي لو کان رقم 

الأب في جدول الآباء عبارة عن 6 خانات وعلى هيئة أرقام فيجب أن 
يكون كذلك في جدول الأبناء. 


لاحظ الآن وبتركيز شديد أنك لو قمت قمت بإضافة 8 سجلات في جدول 
الأبناء انك ستواجه حقلا غريبا موجودا في جدول الأبناء ويتوجب 
عليك أن تضع فيه بيانات حيث لا يمكن أن يكون فارغا. 


ار 


ما هو تعريف المفتاح الرئيسي؟ --- أين المجيبون؟ الووووو 
سابقاء أي آنه في جدول الآباء لا يوجد أي سجل بدون رقم للأب. 


قانون للسيد: 0 °00 1 

لا يمكن للحقل الغريب أن يكون فارغاء من يقول لي لماذا؟ 

لا يمكن للحقل الغريب أن يكون مفتاحا رئيسياء من يقول لي لماذا؟ 
محتويات الحقل الغريب يجب أن تطابق بيانات موجودة أصلا في 
الجدول الذي تم الإستعارة منه. لماذا؟ 


وين الصاحيين معي؟؟؟ !!!هيا للأجوبة على الأسئلة الثلاثة السابقة: 
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فرضا تركنا السجل الرابع في جدول الأبناء بدون استكمال الحقل 
الغريب» ما هي المشكلة؟ المشكلة ان هذا الإبن لن يتم معرفه أباه 
ومن هنا جاء المنع بترك بيانات الحقل الغريب فارغة» بعبارة أخرى 
لن يسمح لك بترکه فارغاء لابد من إدخال قيمة ما. 


لماذا لا يكون الحقل الغريب (رقم الأب) في جدول الأبناء مفتاحا 
رئيسيا؟؟؟ هيا عاد هذي سهلة شباب» لأن من خصائص المفتاح 
الرئيسي هو عدم التكرارء فإذا جعلنا (رقم الأب) في جدول الاأبناء 
مفتاحا رئيسيا فلن نستطيع تكرار الرقم 1 وبهذا لن نستطيع آن 
نجعل لمحمد أحمد عبد القادر أكثر من إبن واحد» واضحة؟ 


السؤال التالث سخيف؟ لا بد ان تستطيع الإجابة عليه !إإتغيير طول 
الحقل الغريب عما هو في الجدول الذي أستعير منه سيخلق مئات 
المشاكل. 


لنعيد شرح الموضوع برمته مرة أخرى !!إوسأسمح الان بإستخدام 
الأكسس» رجاء فقط يستمر معنا الذين يكتبون. 


إفتح الآكسس وقم بإنشاء قاعدة بيانات جديدة وسمها ¥اأ "ه۴ إتفقنا 
سابقا أن كل التسميات باللغة الإنجليزية. 


قم بأنشاء جدول إسمه 16۲5 ج۴ وبه الحقول التالية: 
ex - 4 --‏ --۴atherNumمفتاح‏ رئیسي من نوع نص وبطول 
4 خانات 
FatherName- T1 ext‏ 
FatherAge--Number‏ 
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نشط الحقل ۴an ٥۲ un‏ وإجعله Primary Key‏ أي مفتاحا 


قم بأنشاء جدول إسمه 60۸5 وبه الحقول التالية: 

0NN um-- Number --‏ مفتاح رئیسي 
SonName- Text‏ 

SonAge--Numbe 

۴atherN um -- Number --‏ هذا ھو الحقل الغریب 


نشط الحقل n‏ ں S0 ۸N‏ وإجعله 6y‏ ۲۷۾" ا۴ آي مفتاحا رئیسیا 
بالضغط على المفتاح بشريط الأدوات» إحفظ الجدول وأغلقه. 


من يقول لي ما هو الخطأ الفادح في تصميم الجدولين السابقين؟؟؟!! 
فكر قبل قراءة الجواب؟؟؟ 


الجواب هو الحقل الغريب ۳ں ۲N٥طأج۴‏ في جدول الأبناء نوعه 
ume‏ ينما في الجدول الذي استعیر منه هو ۲٥×‏ بطول 4 
خانات وهذا مخالف للأسس والقوانين. 


عد مرة أخرى وقم بتعديل الحقل الغريب في جدول الأبناء ليصبح 
علی شکل ۲٥×‏ وبطول 4 خانات. 


الآن إفتح جدول الأباء وادخل البيانات التالية في السجل الأول: 
أدخل الإسم فقط: محمد أحمد عبد الله ثم إنتقل للسجل الثانيء ماذا 
حدث؟؟ نعم ظهرت رسالة خطأء ما هي هذه الرسالة ولماذا ظهرت؟ 


مین يیجیب؟؟؟ 


هذا أحد قوانين المفتاح الرئيسي: لا يمكن للمفتاح الرئيسي أن يكون 
قيمة فارغة»ء لابد من وضع قيمة ما فيه. 
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إسمح السجل الأول وقم بإضافة البيانات التالية: 
0محمد سعید أحمد 42 

0خالد عبد الله الصيعري 61 
0سعيد محمد المالکي 32 

0ئلال عبد العزيز المسبحي 29 
0سمير خالد الجار الله 46 

أ حفظ الجدول. 


إفتح جدول لآبناء وأدخل السجل التالي: 
0خالد 9 -- إترك الحقل الغريب فارغا 


مادا حدث؟ مین يجيييييييییییییییييب؟؟؟ واااووووووووو لم يحدث 
شيء» ولكن هذا ينافي قواعد السيد 0000 حيث يقول ان هناك 


شروط: 

لا يمكن للحقل الغريب أن يكون فارغا 

يجب أن يحتوي الحقل الغريب على قيمة موجودة في الجدول الذي 
أستعير منه 

ولكن لم يظهر خطأء لماذا؟؟ 

الجواب: لأننا لم نقم حتى تاريخه بإنشاء العلاقة بين الجدولين. 
نفعل هذا بعد بضعة دقائق بإذن الحق تبارك وتعالى. 

تحياتي»۰۰ 


مرحباء»» 


في هذه الحلقة سأخرج عن الموضوع برمته قليلاً ونعود إليه في 
الحلقة التالية بإذن الله 
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لماذا أقوم بهذا الجهد؟ السبب وبساطة شديدة هو الحصول على أكبر 
كم من الدعوات الصادقة في هذه الليالي الفضيلة. لا اطمح ولا ابحث 
عن شيءَ آخر. 


وقد توقعت أن أجد الآلاف ممن يقرأون هذا الموضوع وهذا لم يتحقق 
بعد بالنظر إلى عدد القراء» ورغبة مني في أرفع هذا الرقم إلى 
الآلاف بل عشرات الآلاف إن أمكن هذا للحصول على دعوات 
صادقة أكثر فقد قررت بعد الاتكال على الحق تبارك وتعالى أن اجعل 
مسابقة لكم لها جائزة قيمة آمل أن تنال إعجابكم. 


وحيث ن الوقت يداهمني حتى 15 أو 20 رمضان سأحاول أن نهي 
هذه الحلقات بأسرع وقت ممكن دون الإخلال بقيمتها أو محتوياتها. 


ماهي المسابقة؟ وأتمنى من القائمين على هذا الموقع المساعدة في 
تنظيمها ووضع الشروط المناسبة لها. 


المسابقة هي تصميم قاعدة بيانات لإدارة مدرسة وحيث أنني أحاول 
ما أستطعت أن أعمق المفاهيم الصحيحة لقواعد البيانات فالمشروع 
سيقتصر على الجداول وعلى الإستعلامات فقطء حيث ستكون 
الإستعلامات هى الإجابة على عشرات الأسئلةء ولإتاحة الفرصة 
للأخوات المشاركات في هذا الموقع فقد قررت بعد الإتكال على الله 
أن يكون هناك جائزتين واحدة لأفضل تصميم من مشارك في الموقعء 
والأخرى لأفضل تصميم من مشاركة في الموقع. وطبعا الجائزتين 
متشابهتين. 


الجائزة هي واحدة لمشارك وأخرى لمشاركة: 
حجز نطاق بإسم الفائز والفائزة حسب اختيارهم (ولا يكون محجوزا 


قبلهم) 
استضافة النظاق والقوقع على الخافم الر تسى الخاض بشركتى في 
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الولايات المتحدة لمدة سنتين 

سعة تخزينية للموقع 350 ميجا بايت 

عدد غير محدود من قواعد البيانات وومع٥A‏ بطاقة تخزينية من 
ضمن 350 میجا بایت 

عدد غير محدود من قواعد البيانات ا@S؟/1‏ بطاقة تخزينية من 
ضمن 350 میجا بایت 

سعة تخزينية بطاقة 50 ميجا بايت لخادم قواعد بيانات Microsoft‏ 


SQL 2000 

المساعدة في إنشاء الموقع مع المساعدة بكيفية ربطه بالآأكىس وال 
SQL‏ 

منتدي مشابه لهذا المنتدى طبعا لأية مواضيع أخرى يختارها الفائز 
والفائزة 


عدد غير محدود من صناديق البريد الإلكتروني 

قائمتين للتحكم واحدة بالمنتدى والأخرى بالخادم 

المساعدة في تصميم الموقع (بدون إخلال بالدين والتقاليد والعادات 
الخادم من النوع المتقدم جدا أي انه يتقبل كل تطبيقات ,اB °٥‏ 
logFrontPage, Visual Interdev, Visual .Net‏ ال 
ذلك. 

الكثير من الخدمات الأخرى على الخادم 


کل ماسبق) مچ الا (لأفضل تصميم من 
رجل وأفضل تصميم من إمرأة. ولكن لمدة سنتين فقط, بعد إنقضاء 
السنتين يقفل الموقع ويلغى كل شيء إلا إذا ارتأى صاحب الجائزة 
الإكمال بسعر 275 ربإل شهريا. بإختصار فإن كل جائزة عينية تصل 
قيمتها إلى 275 × 24 شهر اي 6600 ريإل سعودي أي أن 
الجائزتين بقيمة 13200 ربإال سعودي. 


لیس هذا فقط بل أن الفائز والفائزة سأتيح لهم المشاركة من منازلهم 
في واحد من أضخم مشاريع قواعد البيانات في المملكة العربية 
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التكاليف المدفوعة لهم مقابل عملهم. 


ن ارف فف كن ار عن الو 
والجنسية والجنس (الهدف هو تكثير العدد للحصول على دعوات 
أكثر لشخص يفتقر إلى رحمة الله ومغفرته ورضوانه) 


يمكن تصميم القاعدة إما بالأكسس أو2000 S۵)‏ 


الآن ولإحقاق الحق وخشية أن يبدأ الهواة بالإتصال بمحترفي قواعد 
البيانات ليقوموا بتصميمها نيابة عنهم فأقول: 


ليس الهدف هو الفوز بالجائزة ؟؟؟ الهدف هو أن تتعلم قواعد البيانات 
وباالمقابل تدعو لي. 

إن تصميم تصميم قاعدة البيانات من قبل محترف بإسمك أو نيابة 
عنك هو ظلم للآخرين وإجحاف بحقهم وبحقهن وعليه وعليها أن يتقيا 


اللّه. 

أن يتيح المحترفون الفرصة للآخرين للقراءة والسؤال والفهم وهذا هو 
الهدف من الجائزتين» ولدي القدرة بمشيئة الله أن أعرف من تصميم 
القاعدة أن من قام بتصميمها هو من المحترفين أو المبتدئين. 


إضافة إلى ما سبق سيتم توجهيه 30 سؤالا شفويا بإستخدام الماسنجر 
مثلا للمشاركين للتاكد من فهمهم للموضوع. 


کر و 


لتعميق المصداقية فإن الجائزة لن تنحى إلا إذا لم يشترك أحد !!! أي 
انه لو قام شخص واحد فقط بتقديم القاعدة سيفوز بغض النظر عن 
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تصميمه أو تصميمها!!! 


أي لو قام بالتعديل وإعادة الآرسال قلن يلتفت له حتى لا يكون لدينا 
إرسال المشاركات في 29 شوال حسب تقويم آم القرى حتى لا 
يضطر أحد للتعديل. 


كافة المشاركات في المسابقة ترسل إلى 

s.netئarabserver‏ @®inf0ولا‏ توضع هنا وسأقوم بمشیئة اللہ 
بإدراج إسمي الفائز والفائزة هنا. 

آمل من الأخوة المتابعين معنا وكذلك القائمين على هذا الموقع تنبيهي 
لأية شروط آأخرى لهذه المسابقة وبالذات كيفية منع المحترفين من 
السفار ك ر الفط عله لفرت رها الاكر ين التاتمين» ر كاك 
منع المبتدئين والتائهين من إستخدام محترفين ليصمموا لهم القاعدة. 


أسئلة المسابقة والتصميم في الحلقة القادمة بمشيئة الله. 
ملاحظة هذه المسابقة تم طرحها في عام 3 سنة كتابة الموضوع 
الل لإ عل ل لما لما د انك خان اة واا 
تحياتي»۰۰ 

مرحباء»» 

لا يشترط أن تكون الأسماء معروفة ولن يحبذ جدا لأن العملية مع 


مرور الوقت تتفاقم في التعقيد خذ مثال أنني وأنت قمنا بتصميم قاعدة 
بيانات وأسماء الجداول فيها ۸,8,٥,...‏ وهكذا. 
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ماذا يحدث عندما تصبح قاعدة البيانات فيها 150 جدول؟ 
كيف نفرق بين الجداول واحد أسمه ۸30 والآخر 109 والحقول 
فيها 68 و 9ل العملية ستتعقد بشكل كبير جدا. 


ما هو الحل لمن لديه عوائق في اللغة الإنجليزية؟ 


الحل هو من 3 خطوات: 

الأولى وهي نصيحة عامة للجميع -- هذه فرصة جيدة لتعلم بعض 
اللغة -- قرر بينك وبين نفسك البدء في تعلم كلمات من اللغة 
الإنجليزية ولو بشكل مبسط... صدقني هي لغة تافهة جدا جدا جدا 
راط ها تخل كر لكا لاف خلا وهم افا مدقا 


الثانية: إحصل على قاموس عربي-إنجليزي وليس العكس بحيث 
ار ا ا ار ت ر الو ا 
باللغة الإنجليزية. 


الثالثة: إستخدم |٥٠50 ۷0۲١‏ الوورد الذي يأتي مع الأوفيس 
تحت قائمة الأدوات إختر اللغة ثم الترجمةء يمكنك إختيار الترجمة 
من اللغة العربية للإنجليزية » بعد هذا إكتب كلمة (أب) مثلا ستحصل 
على ترجمتهاا ماج۴ » إفتح صفحة جديدة في الدفتر وأكتب الكلمة 
0 أو 15 مرة وأحفظها عن ظهر قلب. 


إذا فعلت هذا يوميا مع 10 كلمات فقط في نهاية الشهر سيكون لديك 
ما يقارب 300 كلمة إنجليزية........... صدقني في اللغة الإنجليزية 
وللااستخدامات المتعددة جدا لن تحتاج لأكثر من 1500 كلمة -- لغة 
ضحلة جدا أي أنه في بضعة شهور سيكون لديك مجموعة ضخمة 
من الكلمات الإنجليزية التي تكفيك لكل إحتياجات البرمجة والتصميم 
بل صدقنى ستكون بعدها قادرا على قراءة الكثير من الصفحات باللغة 
الإنجليزية. 
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تحياتي»۰۰ 
مرحباء» 


بعد ساعتين ونصف على العمل في أسئلة المسابقةء وجدت أن اقوم 
بتأجيل الأسئلة إلى الغد لأخذ مزيدا من الوقت. فعليه ستکون ادا 
المسابقة غدا بمشيئة الحق تبارك وتعالى. 


نعود إلى الآباء والأبناءء وتعالوا سويا نكتشف بعض ملذات قواعد 
البيانات. 


يسمى المفتاح الأساسي أو الرئيسي وقد فعلنا هذا في الجدولين الأباء 
والأبناء وخصصنا كلا من حقل رقم الأب وحقل رقم الإبن كحقلين 
للمرة المليون: ما هو المفتح الأساسي؟ 


هو حقل يميز كل سجل في قاعدة البيانات ويمنع تكرار البيانات فيه 
لأكثر من سجل واحد ولا يسمح أن يكون فارغا. 


اذا حاو ات إضافة شجل في جدو ل الأباء و الأبناء بدر ن إبخال قيمة 


TS ن‎ ESN 
البيانات في الدنيا. بعد عام 1970 طبعا.‎ 


ثم تحدثنا عن الحقل الغريب. ما هو الحقل الغريب؟ 
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هو حقل يتم إستعارته من جدول ما ويوضع في جدول آخر ولا يمکن 
أن يكون فارغا ويجب ان يكون مشابه لقيمة موجودة في الجدول الذي 
تم منه الإستعارة. سنشرح بتفصيل أكثر بعد قليل. 


او ر افا ا و ا 
من ول الا وو ت اة فول د ولق لن من برك 
لي ماذا يحدث لو عكسنا أي أخذنا رقم الإبن من جدول الأبناء 
ووضعناه (كسلفة) وكحقل غريب في جدول الآباء؟ من يجيب؟ ماهي 
المشكلة في أن نعكس؟ 


للإجابة نعود للمشكلة الأساسية --- ركز -- فكر معي -- هل يمكن أن 
يكون لإبن أكثر من أب واحد؟ الإجابة لا. إذا أول إستنتاج هو أنه لا 
يوجد لأي أبن أكثر من أب واحد» ويمكن أن يكون للأب أكثر من إبن 
EEE‏ 


الآن سأترك إجابة هذا السؤال لكم وأعود إليه مرة أخرى فيما بعد« 
السؤال مرة أخرى لماذا لا يكون الحقل الغريب هو مستعارا من 
جدول الأبناء ويوضع في جدول الآباء؟ أي عكس ما فعلنا حتى الآن. 


وصانا أنه يوجد حقل غريب في جدوJ‏ }ناء إسnم4 FatherNum‏ 
تم إستعارته من جدول الآباء» وقلنا أن أحد شروط قواعد البيانات هو 
أن الحقل الغريب لا يمكن أن يكون فارغا ومع ذلك عندما قمنا 
باضافة السجل: 


0خخالد 9 -- إترك الحقل الغريب فارغاً 
إلى جدول الأبناء لم يحدث أية مشاكل لماذا؟ لأن قاعدة البيانات حتى 


الآن لا تعرف أن هناك علاقة بين الجدولين» السؤال البديهي» كيف 
ننشىء هذه العلاقة. 
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قبل أن تستمر إحذف كافة السجلات من جدول الأبناء؟ !إأين 
الأذكياء؟ من يقول لماذا؟ 


قاعدة عامة: ركز -- إكتب - إحفظ -- تأكد دائما أن الجداول كلها 
فارغة بدون سجلات قبل أن تقوم بإنشاء العلاقات. 


لا تمسح بیانات جدول الآباء حتی وان کان هذا يعارض القاعدة 
ا ا 


لدينا الآن جدولين جدول الآباء وفيه خمس سجلات لأباء مختلفين› 
وجدول الأبناء ولا يوجد فيه أية بيانات. 


أقفل الجدولين تم من قائمة( sامه٣‏ أدوات) أختر 
Relationships )‏ علاقات() 


سيظهر لك صفحة في الخلفية وقائمة فيها أسمي الجدولين: 
الول رل ضط رر اخ فو :` 

نشط الجدول الثاني واضغط زر إضافةلك۸ 

إضغط زر اغلاق أو اقفالموم‌ا© 


ماذا تری.. جدولين في صندوقين وکل صندوق يحتوي على الحقول 
التي قمت بإنشائها. 

إِضغط على حقل ۳ ں۴۲٥‏ ۸ج۴ في جدول الآباء وإستمر بالضغط 
ثم إسحب حتی تصل إلى ٥۲ N1٣‏ ٣ج۴‏ في جدول الابناء ثم إترك 
الا ا 


أريدك عزيزي القارىء ان تستمر بالنظر الت هذه الصفحة لعدة دقائق 
وتقرأ كل كلمة فيها بهدوء وروية. 
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سأعود إليك بعد قليل. 
تحياتي»۰۰ 
مرحباء»» 


ماذا تسمي الأبن الذي فقد أباه ۔۔۔۔۔۔۔۔ صح --- یتیم!!! 


نعود إلى السيد CK05‏ في أحد قوانينه الشهيرة» عند تصميمك لأي 
قاعدة بيانات تأكد أنه لا يوجد أيتام مهما كان الثمن وإلا إنهار التكامل 
والتماسك أ9 6| الخاص بقاعدة البيانات. 


سنعود لهذه النقطة بشرح مسهب. 


أمامك نافذة إسمها (تحرير العلاقات) وتكاد تكون أخطر وأهم نافذة 
على الإطلاق في برامج قواعد البیانات -۔- كل البرامج ولیس 
کش ا 


ماذا نرى في هذه النافذة؟ 


قائمتين مظللاتين لا تستطيع تغير هما واحدة فيها ء6۲طاج۴ أي جدول 
الآباء والاخری 90۸8 اي جدول الأبناء --- تحتهما مباشرة قائمة إذا 
ضغت عليها ترى سرد لكافة حقول كل جدول. 


في الدفتر الذي بين يديك اكتب الجملة الموجودة في مربع الإختيار 
الأول وهي غير منشطة وهي (فرض التكامل المرجعي) وتذكر أن 
كلمة تكامل هي تماساک وهي ما شرحناه سابفاراا gr‏ عiہ|‏ 


موافق. 
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اك عة ا فن ,السو ل 


افتح جدول الأبناء وادخل البيانات التالية: 


0خالد 12 --- إترك الحقل الغريب فارغا وانتقل لسجل جديد - 


- ماذا حدث؟ 

لم يحدث شيء --- !!!!!!!!!! لماذا؟؟ 

الآن أدخل السجل التالي: 

0 سعيد 10 -- وفي الحقل الغريب ادخل 1500 ثم انتقل 
للسجل الثالث 

ماذا حدث؟ ظهر خطا؟؟؟؟؟ لما( ۱۱۱۱۱۱۱۱۱۱۱۱۱۱۱ااذا؟؟؟؟ 


بالإضافة ولكن هذا nT TT‏ 
برامج قواعد البيانات بترك الحقل الغريب فارغا لإفتراض إمكانية 
عدم معرفتك بالقيمة المطلوب إدخالها --- ولكن لحظة من فضلك هذا 
خلل خطير فى تماسك وتكامل قاعدة البيانات» لماذا؟ لأن هذا الإبن لن 
يعرف أباه أبدا وبهذا ينشأ لديك سجل يتيم وهذا ممنوع. 


کي المحاولة الثانية حدث خطأ لماذا؟ لأننا أدخلنا قيمة 1500 کف 
الحقل الغريب وهذه القيمة غير موجودة لأي أب في جدول الآباء 
وامو ق الحرل الو فن ر عندما قلنا أن القيمة في 


الحقل الغريب يجب أن تكون قيمة موجودة في الجدول الذي تم 
الإستعارة منه؟!! 
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أرقام الآباء في جدول الآباء هي 3000 4000 5000 6000 
0 فقط إذا أدخلت فی جدول الأبناء أي قيمة غير القيم الخمس 
السابقة فلن تقبل القيمة --- جرب أية أرقام تريدها إستمر 
بالمحاولة.... لن تستطيع ولن يتم إدخال السجل إلا بقيمة من الخمس 
المذكورة» لماذا؟ لسبب بسيط جدا أنه هذه هي الطريقة التي يتعرف 
بها البرنامج على الاأباءء فاذا أردذت معرفة أب خالك تاخ الرقم من 
الحقل الغريب وتذهب إلى جدول الاأباء وهناك تبحث بهذا الرقم عن 
صاحبه للحصول على الأب. 


والعكس صحيح اذا اردنا أن نعرف من هم ابناء اي اب نبحث عن 


تحیاتی»›»» 
مرحباء»» 


صح --- ما قاله الأخوة صح -- لن يظهر الخطأء تعالوا نصحح 
ونرتب أفكارنا سويا... 


وتعالوا بنا أيضا نجيب على الأسئلة التي تركناها... 


قم عزيزي القارئ بحذف كافة السجلات الموجودة في جدول الأبناء 
قم بإختیار أدوات (sاھ‏ هآ( ومن ûۃp‏ عنڻقlٽ (Relationships)‏ 
ثم إضغط على الخط الواصل بين الجدولين ثم اضغط زر ههام0 
على لوحة المفاتيح ثم وافق على الإلغاء. 


لقد قمت بحذف العلاقة بين الجدولين -- سنقوم بإنشائها مرة أخرى 
بعد قليل. 
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تركنا سؤالا في غاية الأهمية ... لماذا قمنا بإستعارة المفتاح الأساسي 
من جدول اا الأبناء كحقل غريب؟ لماذا لم 
نفعل العكس؟ 


تعالو نفعل العكس ونرى ماذا يحدث للإجابة على هذا السؤال المهم 
والمهم جداء لا تنسوا أن للأب إبن أو اكثر أو لا أطفال» بينما للإبن 


قم بحذف الحقل الغریب ۸ ں ۸6۲۸ھ ۴ من جدول الأبناءء قم 
بإضافة حقل غريب في جدول الاباء وهر ٣ں ۸N‏ 60 تأكد أن الحقل 
NUM‏ في کلا الجدولین هو نص ×۲6 بطول 3g‏ خانات. 


افتح جدول الآباء وتعال معي نضيف طفلين لهذا الأب: 

0 محمد مبارك الحربي 42 

لاحظ أن الحقل الغريب الآن هو رقم الإبن --- لنفترض أن معلومات 
8سعید 7 

7 طارق 9 


بمعنى أنه سنضع في الحقل الغريب الرقم 888 لإضافة الطفل الأول 
إلى الأب أحمد ولا مشكلة في هذا-- قم بوضع 888 لإستكمال إدخال 


ال 
e oS‏ 
أولها نسف كل قو انين C05©5‏ وكل أسس قواعد البيانات العلاقيةء 


انت الآن مضطر إلى تكرار بيانات وهذا ممنوع لأن أحد قوانين 
0هو عدم إدخال نفس البيانات أكثر من مرة واحدةء لیس هذا 
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» ا 


صح --- لأنك مضطر إلى إدخال سجل برقم أب متكرر وهذا یتنافى 
مع قواعد المفتاح الرئيسي وعليه فإن الإبن ذو الرقم 777 لن يضاف 
إطلاقا وبهذا لن نستطيع أن نضيف أكثر من إبن واحد لكل أب وهذا 


قد يأتي من يقول غير حقل رقم الأب ولا تجعله مفتاحا رئيسا وهذا 


طبعا مصيبة لأنه يتنافى مع قواعد K0‏ التي تشترط وجود 
مفتاح أساسي في كل جدول. 


إترك السجل 9000 في جدول الآباء مع ابنه 888 وألغي ادخال 
7 بالضغط على ٥5ع‏ في لوحة المفاتيح. 


إستعارة الحقل من جدول الأبناء خطأ... 
قم بحذف الحقل ۳ں ۸N‏ 80 من جدول الآباء» قم بإضافة حقل 
غریب في جدول الآبناء ٣ں ٥۲‏ ۸ج۴ وتاکد انه نص ٦٥×‏ بطول 


انات 


اضغط آدوات ام٣‏ تم علاقات ومااوہ ھا8 ثم أسحب 
الحقل Father Nun‏ من جدول الاباء وألق4+ عٹ١” FatherNum‏ 
في جدول الأبناء لنعود إلى نافذة تحرير العلاقات. 


واضح أن معظم من معي في هذه الدروس لديهم أكسس بالعربي 
(وهذا مصيبة أخرى) ولكني ساتجاوزها الان ونعود إليها فيما بعد 
!إ1 
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تأكد أن الحقلين الموجودين هما ۳ں ۸٥۲‏ ج۴ من كلا الجدولينء 
إن لم يكونا فقم بإختيارهماء» تعالو نتأمل في هذه النافذة (تحرير 
العلاقات) 


يوجد أربعة أزار --- يهمنا الزر نوع الربط #مرآ امل إضغط 
ار ل ا 


الإختيار الأول وليس لدي بالعربية لكني سأجتهد يعني أنه عند تشابه 
القيمة في ۳ں 6۲ ٣ج۴‏ في الجدولين اظهر القيمة. بمعنى أظهر 
الآباء الذين لديهم أبناء فقط 


الإختيار الثاني: أظهر القيمة من الجدول الأول حتى وإن لم تكن 
موجودة في الجدول الثاني وأظهر أيضا ما تشابه... بمعنى أظهر 
الآباء الذين لدیهم أبناء وكذلك الآباء الذدين لیس لدیهم أبناء 

الإختيار الثالث: أظهر الآباء الذين لديهم أبناء وكذلك الأبناء بدون آباء 


مستر 0000 عمل لنا زحمة --- صح؟ 


لا تفقد الهدف» الهدف هو ليس إنشاء قاعدة بيانات !!! الهدف هو 
كيف نصنع قاعدة بيانات متماسكة ومتكاملة. 


إختر الإختيار الأول وخزن وأخرج من نافذة العلاقات. 


في جدول الأبناء أضف السجلات التالية: 
0 خالد 7 3000 

3000 4 دمحمn10‎ 

10سعید 9 4000 

0 طارق 12 4000 
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140أحمد 5 5000 

0سمیر 17 5000 

160فهد 1 5000 

70مشاري 3 9000 

0 صالح 9 -- إترك الحقل الغريب فارغا -- هذا يتيم بلغة قواعد 
الببانات 

0 ناصر 11 -- إترك الحقل الغريب فارغا 


تعالو بنا نقفز عذة دروس إلى الأمام لتوضيح واحدة من أهم قوانين 
العلاقات في قواعد البيانات ونعود لمكاننا مرة أخرى 


اقفل الجدول وإنتقل إلى الإستعلاماتءم|6ںQ‏ 

نشا إستعلام جديد بدون إستخدام المعالج --- كل المعالجات في 
الاكسس للمراهقين والمقلدين وليس للمحترفين!!! 

نشط كل جدول على حدة وإضغط إضافة ثم أغلق النافذة. 
لاحظ أن العلاقة ما زالت موجودة بين الجدولين 

انقر نقرا مزدوجا على الحقول التالية بالترتيب 

F۴ athe rءءابالا من جدول‎ 


FatherNum 
FatherName 


؟مہsءانبألا من جدول‎ 
SonNum 
SonName 
FatherNum 


60 


الآن ركز --- إنقر نقرا مزدوجا على الخط المرسوم بين الجدولين 
ستظر لك نافذة عنوانها (خصائص الرابط) 


هل ترى الإختيارات الثلاثة --- نعم هي نفسها التي رأيناها في نافذة 
العلاقات. 


الأن جاء دوري للإستمتاع بفنجان القهوة الذي بين يدي وجاء وقتك 


آنا سأستمتع بوقتي وبقهوتي وأنت ستقوم بتنفيذ الإستعلام ثلاث 
مرات» كل مرة تختار خاصية مختلفة من خصائص الرابط ومن تم 
تقول لي ما هي الفروق. 


أريدك أن تصرف عدة دقائق على هذا الإستعلام وترى الفروق بين 
الخصائص 


لنعود إلى0 ٠» 6K05‏ الإختيارات أو الخصائص الثلاث السابقة تسمي 
n‏ أiەل‏ 6۲م االربط الداخلي 
efi Outer Join‏ _الربط الخارجي من الیسار 
Ri ht Outer Join‏ الربط الخارجي من الیمین 


طبعا ليس لها علاقة أن يظهر الجدول سواء في اليمين أو الشمال 
أوکی؟؟؟ 


بعد أن تتأمل كثير وتفكر أكثر في الإختلافات بين الخصائص الثلاثة 
أريدك في الإستعلام أن تقوم بتنشيط الخط الواصل بين الجدولين في 
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الإستعلام ومن ثم تقوم بحذفه بالضغط على زر 6٥اه(‏ في لوحة 
المفاتيح --- نفذ الإستعلام وقل لي ماذا حدث !!! كيف حصلنا على 

0 سجل واا۱۱۱۱۱۱۱۱۱١١١١ااو‏ --- سأفرح كثيرا إن أجاب أحد على هذا 
السؤال. 


إفتح الدفتر وسجل بلغتك وبطريقتك كل ما قلناه هنا 
نعود بعد قليل بمشيئة الحق تبارك وتعالى.. 
تخباتی» 

مرحباء»» 


إذهب إلى صفحة العلاقات من خلال إختيار أدوات ءامه] تم 
عڻقlٽ Relationships‏ 


إحفظ التعديلات 


ثم إنشأ إستعلام جديد بدون إستخدام المعالج -- أضف جدولي الآباء 
والأبناءء ماذا تلاحظ؟ 


مع أننا قد قمنا بإلغاء العلاقة تماما ونهائيا ما زال آکسس یضع 
العلاقة؟ لماذا؟ من يجیب؟ 


لسبب بسيط جداء» لأننا جميعا نتبع القواعد الصحيحة والسليمة لبناء 
قواعد البيانات من خلال إتباع كل القوانين يساعدنا الآكسس وغيره 
من البرامج على إقتراح شكل العلاقات بین الجداول. حيث استنتج 
ات فو الأبناء N‏ ال د الأباء ھر ات 
أساسي (اي واحد) وفي الحقل الغريب ليس مفتاح أساسي (اي يمکن 
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التكرار) أي متعدد. 


أقفل الإستعلام بدون حفظ وعد مرة أخرى لصفحة العلاقات وتعال 
نتأامل في المزيد. 


اسحب مرة أخرى ۳ں ۸6۲ اج۴ من جدول الآباء وأسقطه على 
atherN UM‏ ۴ في جدول الابناء لفتح صفحة تحرير العلاقات. 


راقب مرة أخرى مربع (فرض التكامل المرجعي) وقطعا هي ترجمة 


بأطراف (طبعا ترجمة أسخف من السابقة) بل هي ترجمة سيئة للغاية 
و ف 

اسمحو لي أن اتجراً على شركة ميكروسوفت ونلغي سويا التعبير 
(راس باطراف) ونستبدله بجملة (واحد إلى متعدد) وهي اقرب من 
وجهة نظري إلى الترجمة الحقيفيةny One to Na‏ 


ماذا تعني هذه» أولا تعني أن شكل الرابط بين الجدولين هو (واحد من 
جدول) و (متعدد من جدول آخر) وهذا هو الوضع لدينا E‏ 


لکل أب واحد لدينا عدة أبناء متعددین 


وهذا هو أشهر نوع من انواع العلاقات والروابط بين الجداول 
وأكثرها إستخداما وأكثر ها شيوعا: 


لكل عميل في البنك عدة حسابات 


لكل طالب في الفصل عدة مواد دراسية 
لكل حاسب آلي عدة خصائص مثل الذاكرة والقرص الصلب وغيره 
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لكل مصحف واحد عدهة سور 
لكل سورة في القر ان العظيم عدة آبات 
وهكذا دواليك... 


عند إنشائك لعمارة او فيلا تبدأ بالهيكل الخرساني -- في قواعد 
البيانات هذا الهيكل هو الجداول في قاعدة البيانات ومجموع الجداول 
يسمى 8|60١‏ او الهيكل لقاعدة البيانات» وحيث أن الهيكل 
الخرساني يتميز بالتماسك والتكامل مع بعضه البعض حيث تعمل 
الأعمدة والاأساسات والكمرات مع بعضها البعض لشد المبنى بشکل 
متماسك كذلك تفعل العلاقات بين الجداول في تماسك وتكامل قاعدة 
البيانات 


اكثر العلاقات قوة وشدة وتكامل وتماسك هي (واحد إلى متعدد) 
جملة (واحد إلى متعدد) تفرض علينا إستنتاج إن هناك علاقات أخرى 
وهي: 

واحد إلى واحد 

متعدد إلى متعدد 

بالإستنتاج هناك ثلاث أنواع للعلاقات فقط بين الجداول كلها تساعد 
على تماسك وتكامل الجداول وبالتالي قاعدة البيانات --- مرة أخرى 
اقوى أنواع العلاقات بالترتيب هو: 

One 10o NManyددعتn واحد إل‎ 

One To Onمدحاو واحد إلى‎ 

Many 1o Manyددعتم متعدد إلى‎ 


أما رأس بأطراف --- هههههههههههههه دعك منها 
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مرتبط بعدة سجلات في جدول آخر» سجل واحد من جدول الآباء 
يمتل أب واحد مرتبط بعدة (متعدد) أبناء أو سجلات في جدول 
الأبناء. 

لاحظ في النافذة التي أمامك أن نوع العلاقة لا تستطيع تغيره حسب 
إختيارك» لأن نوع العلاقة هو استنتاج لعملية التصميم وليس إختيار: 
ن کر ا د 
إختيارا. 

ماذا يعني هذا؟ 

يعني أن تغيير تركيبة قواعد البيانات يغير نوع العلاقة (إستنتاجا) 
تعالوا نغير تركيبة قواعد البيانات: 


اغلق صفحة تحرير العلاقات وصفحة العلاقات 


افتح جدول الأبناء وقم بحذف كافة السجلات فيه لتلافي المشاكل في 


افتح جدول الأبناء (بعد حذف السجلات) وقم بتنشيط الحقل الغريب»› 
إجعل الحقل الغريب هو المفتاح الأساسي. 


احفظ التعديلات. 


افتح صفحة العلاقات من أدو ات تم علاقات 
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انقر نقرا مزدوجا على خط العلاقة --- أين المجيبون --- ماذا حدث؟ 


هل تری نوع العلاقة؟؟؟ طبعا دعك من رأس برأس --- حسب إتفاقنا 
آصبحت واحد إلی واحد 0"6 ۲١‏ 0"6 لماذا؟؟ 


EUR E E EEE EES SEES هیا عاد‎ 


الربط الآن يتم بين حقلين كليهما مفتاح أساسي وأحد شروط المفتاح 
الأساسي هي عدم التكرار وعدم التكرار يعني (واحد) فقط» 
وبالتالي في جدول الآباء لدينا أب واحد وفي جدول الأبناء لا نستطيع 
التكرار أي إبن واحد أي أن العلاقة أصبحت واحد لواحد أو واحد إلى 
واحد. 


سؤال متقدم للمحترفين والأذكياء --- متى نحتاج إلى علاقة على شكل 
واحد إلى واحد؟ ما أهميتها؟ ذكروني فيما بعد لأساعدكم على الإجابة. 


واحد إلى واحد هو ثاني أقوى أنواع العلاقات بين الجداول. 


CODD 


قم بتعديل تصميم الجدولين بحيث لا يوجد اي مفتاح رئيسي في 
فيهماء لا تحذف الحقول» فقط لا تجعلها مفاتيح رئيسية. 


أذهب إلى العلاقات وانقر بشكل مزدوج على الخط --- ما هو نوع 
العلاقة الآن؟ 


غير معرف أو عأج١‏ "6۲هل م| او بالترجمة الفعلية (غير 
محدد)... ضاع الآكسس ولا يعرف ماذا تريد وأصبحت قاعدة 
البيانات هشة وقابلة للكسر في أي لحظة. 
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العلاقة (متعدد إلى متعدد) في غاية الأهمية وللأسف (صعبة شوي) 
وحتى لا نمزق افكارنا سنؤخرها إلى ما بعد فهم العلاقة الأساسية 


الآن ولزيادة التعذيب آمل منك إعادة تصحيح الجدولين وكذلك إعادة 
إنشاء العلاقة بينهما على شكل واحد إلى متعدد واعادة إدخال العشر 
أطفال مرة أخرى. 


نستكمل مع العلاقات بعد قليل. 


تحیاتی»›»»› 


مرحباء»» 
نستكمل ثم نعود للأخ (-) في تصحيحه لنا من عدم ظهور الخطاً!!! 


إلى أين وصانا الآن؟؟؟ ماذا أمامنا؟ كل العملية تدور حول تماسك 
وتکامل قاعدة البيانات› هذا التماسك يتم من إنشاءِ جداول صحيحة 
حسب القوانين وکل جدول فيه مفتاح رئيسي» ويتم الربط (%90) 
بنوع واحد إلى متعدد ويوجد هناك ثلاثة خصائص لكل نوع (داخلي»› 
خارجي يمين» وخارجي يسار) 


ey‏ اntاهي‏ التكامل والتماسك 

rien Fie‏ ۴هو الحقل الغريب ومن خصائصه: 

عدم إمكانية التكرار (الا إذا اردت الربط على شكل واحد إلى واحد) 
ألا يكون مفتاحا رئيسيا (الا إذا اردت الربط على شكل واحد إلى 
واحد) 

ألا يكون فارغا حتى لا يصبح السجل يتيما 

أن تكون القيمة المدخلة فيه مشابهة لأحد الأقيام الموجودة في الجدول 
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الآخر لا يصبح السجل يتيما. 


نستمر وما زلنا نحاول ونجاهد أن نصمم قواعد بيانات (متكاملة) و 
(متماسكة) 


لدينا في جدول الآباء 6 آباء حاليا أرقامهم 3000 4000 5000 
6000 7000 9000 

ولدينا في جدول الأبناء 10 أطفال أرقامهم 110 120 130 140 
150 160 170 180 190 


atherN Um‏ ۴هو رقم الأب وهو المفتاح الأساسي في جدول 


0NN‏ خو رقم الإبن وهو المفتاح الأساسي في جدول الأبناء. 


يوجد فرض للتكامل المرجعي. 


الآن إفتح أستعلام جديد وأضف الحقول التالية: 
FatherNum‏ 

FatherName 

SonNum 

SonName 

FatherNum 


تفذ الإستعلام واكتب ما يلي في الدقتر عندك: 
يوجد 6 آباء و 10 أطفال 


أنشأً جدولا بالمسطرة والقلم وقم بنقل سجلات جدول الآباء حتى 


تستطيع أن تراها 
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أنشاً جدولا بالمسطرة والقلم وقم بنقل سجلات جدول الأبناء حتى 


تستطيع أن تراها 


عندما ترى في الإستعلام خط بين جدولين فهو يعني الخاصية الأولى 
(اي نوع داخلي) وكما قلنا فالنوع الداخلي يظهر فقط السجلات من 
الجدولين التي تتشابه فيها الحقول المروبطة وعليه حصلنا على 4 
آباء ڍ فقط ولم نحصل لا على الأب رقم 6000 ولا على الأب رقم 
0 لمادذا؟ 


لان هڏذين الأبوين ليس لهم أي أطفال وهذا منطقي ولكنه 
جدا من نأحية التماسك !!! لماذا؟؟؟ 


لأن الإستعلام الذي بين يدينا لا يعطينا كم أب لدينا؟ نحن لدينا 6 آباء 
والإستعلام يقول 4 وهذا فيه مخاطرة. خذ هذا المثالء لدينا 50 طالبا 
في الفصل كل منهم قام بتسجيل 3 مواد ما عدا 4 طلاب» عدم 
تسجيل الطلاب لأية مواد ممنوع» كيف نعرف انه يوجد طلاب بدون 
مواد؟ 


مرة ة أخرى استصدار السجلات التي تتطابق فيها الحقول المربوطة قد 
يؤدي إلى مشاكل كثيرة في تحليل البيانات وتحويلها إلى معلومات 
للتخطيط و إتخاذ القرارات. 


في الإستعلام غير خاصية الرابط إلى النوع الثالث وليس الثاني. 
لاحظ أن السهم يتجه إلى جدول الآباء. 


ركز معي: السهم يعني فقط السجلات التي تتشابه فيها الحقول 
المربوطة. عدم وجود السهم يعني كل السجلات. في هذه الحالة 
طرف الخط عند جدول الأبناء لا يوجد فيه سهم وهذا يعني (كل 
السجلات) أي كل الأبناء» وطرف الخط عند جدول الآباء فيه سهم 
ويعني فقط الأباء الذين رقمهم مشابه لرقم في الجدول الآخر. 
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کا ل ا 0000 ى ا 
ناء مء ولكن بالمقال حصنا على طظلين أخرين 180 و 190 


وهذا أخطر ما يمكن أن يحدث فى قواعد البيانات E‏ 
سجلات في جدول (المتعدد) بدون سجلات في جدول (الواحد) وهذا 
يؤدي إلى سجلات (يتيمة) وينسف تماسك وتكامل قاعدة البيانات من 
جذورها. 


عندما تحصل على سجلات في جدول المتعدد لا ترتبط بسجلات في 
جدول الواحد فلديك مصيبة في قاعدة البيانات وهي من اكثر الأخطاء 
شيو عا ومن أصعب المشاكل حلا. 


الأن غير إلى النوع او الخاصية الثانية وبهذا يتجه السهم إلى جدول 
الأبناء. نفذ الإستعلام سرى كل الأباء من جدول الأباء وسترى أيضا 
أن هناك أبين ليس لهما أبناء. وهذا أفضل نتيجة تحصل عليهاء بل أن 
معظم التطبيقات تستخدم هذا النوع. 


كما تلاحظ فإن اليتمين لم يظهرا هنا رقم 180 و 190 وهما المشكلة 
الأساسية الآن في تماسك القاعدة. 


نعود لصديقنا (-( الذي جزاه الله خيرا نبهنا إلى عدم ظهور خطأ عند 
اختراق أحد قوانين C000‏ وإضافة رقم غير موجود في جدول 
الواح ال الل الفرنف 


تعالوا نعيد هذه التجربة تم نقول للأخ (-) لماذا لم يظهر الخطأ (وهو 
طبعا ليس بسبب التكامل المرجعي) ... نوعا ما... سنشرح بعد قليل. 
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لدينا 6 آباء بأرقام 3000 4000 5000 6000 7000 9000 


افتح جدول الأبناء وإذهب إلى الإبن رقم 180 الذي ليس له أب 
وأدخل أي قيمة في الحقل الغريب. سيقبل منك دون أي خطأ لماذا؟ 


نعود لمستر ٥0000‏ 
ماهي خصائص الحقل الغريب: 


الآ يكون فارغا والا نتج سجل يتيم 

أن يكون مشابها لقيمة في الحقل المربوط فيه أي أحد الأقيام التالية 
)3000 4000 5000 6000 7000 9000( اي قيمة أخرى 
غير هذه القيم الست تؤدي إلى سجل يتيم لان الربط يتم بتشابه القيمة 
بين الحقلين المربوطين. 


الإجابة وببساطة هي: لصيانة قواعد البيانات. 


هذا التساهل قي برامج قواعد البياتات والسماح باختراق أحد قوائين 
الوقت للتطرق اليه مستقبلا لأهميته. 


هل لازلت متخيلا معي أن قاعدة البيانات فيها آلاف الجداول وكل 


ماذا لو كنت تقوم بصilة Administrating & Maintaining‏ 
هذه القاعدة؟ 

ماذا لو كنت نتقل ملايين السجلات من قاعدة البيانات إلى نسخة 
إحتياطيةء إذا منعك الآكسس لخلل في تماسك القاعدة فلن تحصل على 
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قبل النسخ. 

ماذا لو تسرع مدخل البيانات وأدخل بیانات الأبناء وأنت ما زلت 
تصمم القاعدة ليوفر الوقت» إذا منعه الأكسس فلن يستطيع إستكمال 
سجلات جدول الأبناء قبل أن يقوم بإدخال بيانات الأباء. 


نعم هو تساهل ولكن له خدمات كثيرة» هذا التساهل أخف بكثير في 
البرامج الأخرى مثل أوراكل وغيرها. 


إذا لا علاقة بالموضوع حتى الآن (بفرض التكامل المرجعي) هذا 
قواعد البيانات. 


وهذه مشكلة لا نواجهها نحن حالياء لأن قاعدة البيانات التي نقوم 
بتصميمها جديدة ومن الصفر ولا يوجد لدينا بيانات ولا صيانة ولا 
شيء. 


مرة أخرى سمح لك الآكسس بإدخال قيم (غير شرعية) تساهلا بأحد 
القوانين لتبسيط عمليات النسخ والصيانة والتجربة والخطأ. 


ونستغل الوضع هنا من تنبيه الأخ (-) لنقول حذار من البدء في 
إدخال البيانات لقاعدة بيانات لم تتكامل ولم تتماسك بعد... تذكرون 
عندما طلبت حذف كافة سجلات جدول الأبناء لإجراء بعض 


التجارب» لماذا؟ حتى لا نقع فيما نبهنا إليه الأخ -. 


بعد تقديم الشكر للأخ الصاحي معنا (بل الصاحى جدا)» نعود ١‏ 
و ي حي توو 
الأيتام في سجل الأبناء. 


الآكسس لم يساعدنا في منع وجود أيتام في قاعدة البيانات» والقانون 
ينص على أن وجود آيتام سيؤدي إلى مشاكل بالكيلو. 
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تعال وشاهد معي مدی هشاشة قاعدة البيانات التي نقوم بتصميمها 
افتح جدول الأباء وقم بحذف الأب صاحب الرقم 3000 ثم احفظ 
اذهب واعبث قليلا في الإستعلام الأخير الذي قمنا بإنشائه. 


اختر النوع الثالث من خصائص العلاقة لرؤية الأيتام؟؟ ماذا ترى؟ 
أصبح لدينا يتام بالهبل بعد ذبح أبيهم!!! 


س ها فط بن م لى رن الا ر عر رف الات و400 اى 
4500 تم عد تنفید االإستعلام»» ماذا حدث؟؟؟ 


اة انات م ور ا عل الا 

اعد إدراج بيانات الأب رقم 3000 مرة أخرى في جدول الآباء 
وصحح بيانات 4500 إلى 4000 مرة أخرى. 

وأسمحوا لي بفنجان من القهوة. 


تحیاتی»»»› 


مرحباء»» 


مازلت في مرحلة إنشاء أسئلة المسابقة -- وآمل أن أستطيع إنهائها 
الليلة بمشيئة الله. 


نعود إلى العم C000‏ والعلاقات» ونكرر أن ما نقوله هنا ليس له 
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علاقة بأي برنامج بل ينطبق على Oracle‏ ڍ Microsoft SQL‏ 
وغیرهم ايضا. 


ما زال هدفنا هو تماسك وتكامل قاعدة البيانات كذلك تسهيل عملية 
إدخال البيانات لصديقنا المسكين (مدخل البيانات) 


ووصانا أن قاعدة البيانات لدينا ما زالت هشة وقابلة للكسر لسبب أن 
طريقة تصميمها تتيح للحقل الغريب أن يحتوى بيانات غير موجودة 


لنزيد من حجم المشكلة قليلا للتفاعل مع صديقنا (-)» إذهب إلى 
صفحة العلاقات من أدوات ثم علاقات. 


إختيار (فرض التكامل المرجعي) سيظهر لك مربعان إضافيان 
اتركهما الان بدون علامة صح. إضغط موافق» ماذا حدث؟؟؟؟ 


القضاء u‏ إحتمالية تولد کم فی فا ا البيانات !!! ولهذا قر نك 
أْماذ|؟؟؟ 


صح -- لأن قاعدة البيانات أصلا فيها أيتام. 


ما هي المشاكل التي نحاول حلها والتي واجهتنا في الحلقة السابقة: 
نستطيع ترك الحقل الغريب فارغا 

نستطيع ادخال اي قيمة في الحقل الغريب دون شرط وجودها في 
الحقل المرتبط فيه 

نستطيع حذف أب وترك آبنائه بدون أب --- أیتامOrphans‏ 
نستطيع تعديل رقم الأب في جدول الآباء من 4000 إلى 4500 
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وبهذا يفقد الأب أولاده المرتبطين فيه على رقم 4000 وليس 4500 


كل ما سبق مشاكل تؤدي إلى عدم تكامل وتماسك قاعدة البيانات -- لا 
بد من حل المشاكل الأربعة السابقة واحدة تلو الأخرى. 


i 


اذهب إلى جدول الأبناء وقم بوضع أب للطفلين 180 و 190 وليكن 
ابوهما رقم 6000 
أي ادخل 6000 في الحقل الغريب. 


لنتأكد من السجلات. 


في جدول الاآباء 
N0محمد‏ سعید أحمد42 
0خالد عبد الله الصيعري 61 
0 سعيد محمد المالكي 32 
0سطلال عبد العزيز المسبحي29 
0سمير خالد الجار الله46 
0احمد مبارك الحربي42 


في جدول الأبناء 

10 خالد 3000 7 
110محمد3000 4 
0 سعيد4000 9 
0 طارق4000 12 
140أحمد5000 5 
0 سمیر 5000 1⁄7 
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0 1فهد5000 1 
70 مشاري9000 3 
180ص6000 9 
0 ناصر6000 11 


اذهب مرة أخرى الى العلاقات وضع صح على مربع فرض التكامل 
واترك المربعين الأاخرين فارغين. 


افتح جدول الأبناء وأضف الطفل التالي: 
0-سلطان 12 


وحاول أن تضع أي قيمة غير القيم التالية (3000» 4000» 5000» 
600؛ ۰7000 9000) وکذلك لا تترکه فارغا. 


ماهي المشكلة التي تم حلها من الأربعة مشاكل نښعاليه؟ 


تم حل المشكلة الثانية حسب الترتيب السابق» الآن إما أن تضع قيمة 
موجودة في جدول الآباء أو ن تترکه فارغا... لن يستطیع مدخل 
البيانات الآن إختراع قيمة من عنده. 


إذهب إلى جدول الآباء -- حاول حذف أي أب له أبناء مثل الأب رقم 
0 مممممم لا تستطيع مهما حاولت لأن ذبح الأب سيترك ... 
ماذا؟ نعم أيتام ولهذا فهو ممنوع. 

حاول تعديل رقم أي أب له أبناء مثل الأب رقم 4000 حاول أن 
تجعله 4500 !إإمممممممم لا تستطيع مهما حاولت لان تغيير رقم 
الاب سيترك كل الاأطفال الذين أبوهم رقمه 4000 بدون آب. 
جدول الأبناء فارغاء ومن التجربة العملية في السوق أقترح ترك هذه 
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ارد فا د اتو م ا ما ع ف لرن 
ومن تم حلها فيما بعد. لماذا؟ 


نعود لصديقنا (-) وتوجيهه لناء السبب هو أننا في مرحلة التفكير 
والتكامل لقاعدة البيانات ولا نريد كل دقيقة أن ينط لنا الآأكىس او إاس 


كيو إل ويظهر لنا خطأ ما 


أما كيف نحل المشكلة الرابعة فهي من خصائص الحقولء إفتح جدول 
الأبناء ذ في التصميم ونشط الحقل الغريب وأنظر في الأسفل سترى 
خاصية (مطلوب) أو ١٥۵‏ أا» ه8 عند تعديلها من (لا) إلى (نعم) لا 
نستطيع ترك الحقل الغريب فارغا. 


لدينا الآن قاعدة بيlنlٽت Intergated‏ أي متكاملة ومتماسكة --- 
ولكن لحظة .... توقف... 


يو جد مصيبة في هذا التصمn!‏ !!!| IIIIIIIIIIII!!|!!!1!‏ 


بو جد الآن مشاكل حقيقية في تصميم قاعدة البيانات حتى مع تماسكها 
وتكاملها. 


من يقول لي لمادا؟ 
فکرووووووووووووووووووووووووووا 


ولا تنسوا و القراءة لا تفيد ---- إكتبوا كل الملاحظات. 
تحياتي»۰۰ 
مرحباء»» 


أولاً... للأخ (---) الله ما أجمل وأروع إجابتك وبالذات الإجابة على 
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سؤال متى نستخدم العلاقة واحد إلى واحد. 


بالهنرهط -- في حالة واحدة فقط -- عندما نحتاج إلى زيادة النواحي 
الأمنية في قاعدة البيانات (طبعا ليس حماية قواعد البيانات بل حماية 
البيانات نفسها من الإطلاع عليها) ويتم هذا بفص حقول الجدول 
الواحد إلى جدولين أو أكثر ويربط بينهما بنفس المفتاح الرئيسي -- 
العلاقة واحد إلى واحد تعني أن الربط يتم بين مفتاحين رئيسيين. اما 
كيف نفصل بين الجدولين وكيف نوزع الحقول فهذا جزئية قد نتحدث 
عنھا إذا عفن لوقت yتسnأٴ Normalization‏ 


لدينا الآن قاعدة بيانات تنطبق فيها كل قوانين C000‏ ومتكاملة 
ومتماسكة. ولكن فيها مشكلتين أساسيتين تطرق بعض الأخوة لهما: 


المشكلة الأولى: ماذا نفعل إذا أردنا فعلا أن نحذف أي أب؟ 
المشكلة الثانية: ماذا نفعل إذا أردنا فعلا أن نغير رقم أي أب؟ 


في التصميم الحالي لا نستطيع؟؟؟ 


لحظة.... ركز معي 

إذا كان الأب بدون أطفالء فلا مشكلة لدينا -- نستطيع حذفة وهذا لا 
ينتج عنه أيتام» وكذلك نستطيع أن نغير رقمه وأيضا لا ينتج عن هذا 
أيتام. بالإستنتاج نستطيع أن نحذف أب بعد أن نقوم أولا بحذف كل 

أولاده. ولكن هذا فيه اجهاد كبير لماذا؟ 


لأننا نتخيل أن قاعدة البيانات فيها 5000 جدول وكل جدول فيه آلاف 
الحقول وكل جدول فيه ملايين السجلات» هل من المنطقي والعملي 
أن نذهب كل مرة إلى جدول (المتعدد) ونحذف السجلات كلها تم 
نذهب إلى جدول الواحد وحذف سجل واحد من هناك» طبعا العملية 
مجهدة وقابلة للأخطاء... لا بد من وجود حل عملي ومنطقي. 


78 


أعد قر أءة المشكات أعلاه ر SE UCA ESR E EIT‏ 
ګر بہمحں 3 


افتح صفحة العلاقات من أدوات ثم علاقات من القائمة. 
نقر مزدوج على الخط الواصل بين الجدولين. 


ET aT 


واحدة فيها كلمة (تحديث مأولملل )و الأخرى فيها (حذف ) 
اوهو ما نبحث عنه فعلیاًء صح؟ 


إقرأً مرة أخرى بتمعن وتركيز أكبر» ستجد ان الحذف يتعلق 
بالسجلات ....مممم 

وأن التحديث يتعلق بالحقول .... ممممممممم 

كالعادة» لما( اا1 111111١١١١١١١اذا؟‏ 

ماذا يعني کل ما سبق»›» عن ماذا نبحث؟ ماذا نفعل؟ 


نريد حلا للمشكلتين أعلاه... 


نريد عن تعديل أو تحديث رقم الأب في جدول الآباء ----- ماذا؟ أين 
يتم تلقائيا تحديث رقم هذا الأب في جدول الأبناء. 


ضع علامة صح على الإختيار الأول (تحديث الحقول المرتبطة) --- 
اقفل النافذة 
إذهب إلى جدول الآباء وغير (عدل) (حدث) رقم الأب 4000 إلى 
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4500 


ماذا حدث؟؟ 


ممه همهم ممم ---- لم يظهر خطا: 


أقفل جدول الأباء وإفتح جدول الأبناء --- الآن يجب أن تجيب ماذا 
حدث؟ ماذا تغیر؟ 


آلیا قام الآکسس أو 0۲۵٥16‏ أو SQ)‏ ۸8 بتحدیث -- بتغيير -- 
ا ت ا کی ل اه 
(المرتبط) ولا يوجد الآن أب برقم 4000 كل أب يحمل الرقم القديم 
أصبح الان يحمل الرقم 4500 


هل تلاحظ التماسك والتكامل --- لا يمكن صناعة أيتام -- أقفل 
الجدول 


بالإستنتاج وبالقياس نذهب إلى العلاقات مرة أخرى من أدوات ثم 
علاقات 


الآن ضع علامة صح على الخاصية الثانية (حذف السجلات) -- 
أعتقد أنها واضحة الآن 

إضغط موافق وأقفل صفحة العلاقات تم إفتح جدول الآباء. 

قم بحذف الأب صاحب الرقم 4500 -- ماذا تقول الرسالة؟ لاحظ في 
السابق كان الحذف ممنوعاً ولكنه الآن يقول لك في الرسالة (لا بأس) 
سأحذف لك هذا الأب ولكن بشرط واحد هو أنني سأحذف كل أولاده 
أولاً -- هل توافق؟ إضغط نعم. 


تم حذف الأب --- ليس هذا فقط --- اقفل جدول الآباء وأفتح جدول 
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الأبناءء ماذا تلاحظ؟ 

نعم لا وجود لأي إبن بأب ذو رقم 4500 

قاعدة بيانات متكاملة ومتماسكة من الدرجة الأولى. 

الرجاء ممن لم يشتغلوا معي خطوة بخطوة عدم الاستمرار حيث 
تفهم أقرأ وطبق يدويا من الاول. 


تعالوا بنا الآن نزيد قليلا من التعقيد ولا تنسوا أن الهدف خلال رحلتنا 
كاملا هن العخافطة عل الاه و الكاقل. 


تحیاتی»›»»› 
مرحباء»» 


في حوالي %90 من الحالات العلاقة بين الجداول هي واحد إلى 
متعدد وفي حوالي 1 هي واحد إلى واحد. 


ی ی ا 


ولكن عالم قواعد البيانات ليس سهلاً دائما وممتعاء تعال نحاول حل 
هذه المشكلةء في ترقيم السيارات عندنا في المملكة العربية السعودية 
مثلاً لوحات السيارات تأخذ 6 خانات ثلاثة أحرف وثلاثة أرقاي 
عندنا نريد إنشاء قاعدة بيانات لكافة سيارات المملكة لدينا مشكلة 
أساسية 


ا ا ا 
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الحل الأول هو إنشاء مفتاح رئيسي يتكون من 6 خانات وهذا قد 
يكون حلا سريعا للمشكلة ولكنه يتطلب حلولا برمجية للمساعدة متلا 
لعمل 4أممج" أو ترسيم بين الحروف العربية والحروف اللاتينية 
منلا. 

لنسهل الموضوع ونفترض أن الإدارة العامة للمرور منعتنا من 
إستخدام حقل واحد. 

ما هو الحل... إنشاء حقلين كل واحد منهما 3 خانات» وبهذا يصبح 
لدينا حقل من ثلاثة أرقام وحقل آخر من ثلاثة حروف. ولتسهيل 
العملية سأفترض أن الحروف باللغة الإنجليزية متلا للهروب من 
التقة ف ال العرية رن الهف در قم ارات لان الا فى 
أن نفهم سويا الموضوع) 


وبهذا لترقيم سيارة ما 376 ۸1-۲ بحيث نضع K1‏ في حقل 
ونضع الرقم 376 في حقل آخر 


هذا حل جيد (حتى وإن كنت لا أحبذه إطلاقا من الخبرة) ولكن الهدف 
هو شرح الموضوع. 


الأن ما هو المفتاح الرئيسي لهذا الجدول. 

إنشأً جدولا في قاعدة البيانات ۷اا ه۴ وفيه الحقلان التاليان: 

أ اateا۴نص‏ 3 -- للكناية عن الأحرف الثلاثة لرقم لوحة السيارة 
Um‏ ateNا۴نص‏ 3 -- للكناية عن الأرقام الثلاثة لرقم لوحة 
السيارة 


لا تنس قاعدة مستر 6K05‏ والتي تنص على أن لكل جدول مفتاح 
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أساسي» لاحظ كلمة (مفتاح) وليس (مفاتيح !!!! )واضح؟ 


مرة أخرى للتأكد من طرح الموضوع بشكل جيد --- مفتاح واحد فقط 
وليس مجموعة من المفاتيح. 


نعود إلى لوحة السيارة --- ما هو المفتاح الرئيسي في هذا الجدول 
علما بأنه يوجد لدينا الآن أربع سيارات لوحاتها كالتالي: 


رقم لوحة السيارة الأولى376 K1‏ --- 
رقم لوحة السيارة الثانية950 1 ) --- 
رقم لوحة السيارة الثالثة376 85 --- 
رقم لوحة السيارة الرابعة 950 8×0 --- 


لنفترض أن الحقل 6 ٥ج۴‏ الخاص بالحروف هو المفتاح 
اھ ا ا 

صح» لن نستطیع تكرار البيانات في هذا الحقل وبالتالي لن نستطيع 
إدخال آ1 وكذلك 810 أكثر من مرة واحدة --- مشكلة --- هذا 
الکلا یسل ان رکون متاخ رتا 


لنفترض أن الحقل ٠‏ ں ۴|٥‏ الخاص بالأرقام هو المفتاح 

الر تسى د ما هي الك 

صح» لن نستطيع تكرار البيانات في هذا الحقل وبالتالي لن نستطيع 
إدخال 376 وكذلك 950 أكثر من مرة واحدة ---- مشكلة --- هذا 
الحقل لا يصلح أن يكون مفتاحا رئيسيا. 


لدينا حقلين فقط وكلاهما لايصلح أن يكون مفتاحا أساسيا وفي نفس 


الوقت لا بد من وجود مفتاح أساسي؟؟؟ معضلة !! وطبعا لم تسمح لنا 
ادارة المرور بإاضافة حقل جديد ندعيه أساسيا. 


83 


ما هو الحل؟ 


يقول لنا C050‏ إذا كنت مضطرا لجعل المفتاح الرئيسي يتكون من 
کنر من حفن فلا بان وگن ا شن ان هدا لجل فط عتا تكرن 
مضطرا. . . 


واضح أن كلمة (مضطرا) هذه تعني إستثناء وليس قاعدة وهي تعني 
أ ان تحار ل الر ت ن كال ف ليطا فة وك هت 
SCS O lS SISE a‏ 


قم بتنشیط الحقلین 16٥ھ‏ ا۴ و Num‏ مatاP۴‏ مع بعضهھما البعض 
من خلال الضغط والسحب من أقصى اليسار أو أقصى اليمين حسب 
الآكسس لديك ومن ثم إضغط المفتاح في شريط الأدوات. 


الآن ركز بشدة معي--- لا يوجد أكثر من مفتاح أساسي في الجدول - 
- متفقين؟ 
إذا ماذا نسمي الذي أمامنا؟ 


الذي أماماك الآن هو مفتاح أساسي واحد فقط ولکن يتكکون من حقلين 
إثنين!!! 
ماذا يعني هذا؟ 


ا كل حقل على حدة!!!! 
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لخو الا وک کل عل خا 


تعالوا بنا نفهم بشكل أفضل 


خزن الجدول بإسم ها۴ بعد أن تطمئن انه يوجد رسمة مفتاح 
بجانب كل حقل من الحقلين. 


تعالوا بنا ندخل بيانات في هذا الجدول... 


أدخل الحروف ۲ K1‏ في حقل ع ها۴ تم حاول الإنتقال إلى 
السجل التالي--- ماذا حدث؟ کا طبعاء»» لماذا؟ لأن حفل المفتاح 
الأساسي لا يمكن أن يكون فارغا -- ولكننا وضعنا قيمة في هذا 
الحقل --- صح وضعنا قيمة في حقل 16٥ج‏ |۴ ولكنه ليس هو 
اح الأساسي -- مره ر ماهو اج الاي في هذا الجدول 
البعض ولیس ع1 ع۾|۴ لوحدها وكذلك س PlateNum‏ 
لوحدها. 


امسح القیمة ۸۲ وحاول إدخال 950 في حقل ہںماھا۴ لن 
إذا كان المفتاح الأساسي يتكون من حاصل جمع أكثر من حقل فإن 
لن تسد تستطيع الإنتقال من هذا ١‏ لسجل إلا في حالة واحدة فقط وهي 


إدخال K1‏ في ع اعاه|۴ وكذلك إدخال 950 في PlateNum‏ 
وهذا منطقي حسب ما فهمناه. 
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قم بإدخال السجل السابق وتعال ندخل سويا سجلا آخر وهو 11 
6 حظ أن الآأكسس وكذلك الأوراكل وغيرهما سيسمحون لك 
بإادخال هذه اللوحة ... من يجيب لماذا؟ 


لماذا سمح لنا الأکسس بتكرار K1‏ في حقل† م ]ماما۴ ؟ من 


٠: لحلل‎ 
UCT 


الإجابة لأن ۴|٥6‏ ليس مفتاحا رئيسيا 
الإجابة لان ٣ں‏ ماھ|۴ لیس مفتاحا رئيسیيا 


تحياتي»۰۰ 
مرحباء»» 


بالنسبة للأخوة والأخوات الذين يسألون عن بريدي الإلكتروني فهو 
Info@arabserver.net‏ [ 

بالنسبة للاخ الذي وضع القوانين الخاصة بالسيد 00 K0‏ فاتقدم له 
بجزيل الشكر راجيا من الجميع: 


عدم ترجمتها إلى اللغة العربية ونشرها -- حتى لا تؤدي إلى بلبلة 


ملاحظة أن القوانين من القانون التاسع إلى القانون الثاني عشر لم 
تطبق حتى الآن في أي لغة قواعد بيانات لا الأكسس ولا الأوراكل 
ولا 1S SQ]‏ ولا غيرهاء وبالتالي لم يتم إنشاء أي قاعدة بيانات 
علاقية في العالم تتبنى القوانين من 9 إلى 12. 
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أما إقتراح الأخ بتجميع كل المشاركة في ملف وورد فآمل منه 
أن يقوم بهذه نيابة عني شاكرا ومقدرا له هذا الجهد. 


نعود... 


كم آنا سعيد أن وأنا أقرأً الإجابات على السؤال الذي تركناه في الحلقة 
السابقة وقد كانت كل الإجابات صحيحة وتشرح الصدر. فعلاً أصبح 
المفتح الأساسي هو ناتج مجموع قيمتي الحقلين وبهذا لن تستطيع 
تكرار رقم اللوحة الذي يتكرر في كلا الحقلين. 


لنشن خذرل واوا الخاص ارقا أرحات ارات و نکی مد 
بهذا القدر. 


قم بإنشاء الجدول التالي سواء في الآأكسس أو الأوراكل أو MS‏ 
ا S۵وهو‏ جدول الأصناف إطلق عليه الإسم ئ" ]| وضع فيه 
الحقول التالية. 


NUM‏ temانص‏ 2 -- مفتاح اساسي 
temNameانص‏ 
em Co‏ tارقnم‏ 


إحفظ الجدول بإسمء ]| 


أضف السجلات التالية في جدول الأصناف: وم )| 
0محاية2 
91مسطر 45 
2قلم رصاص 1 
93منقلة2 
94قلم حبر15 
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5سبورة45 
6الة حاسبة20 
7براية1 
98شنطة70 
99دفترق 


النظر عن المنطق) أي آمل ألا يقول أحد أن طفلا عمره سنة واحدة 
قد إشترى منقلة!!! 


آین نحن؟؟ 


س الأصناف السابقة لأطفاله ثم نر يد إنشاء إستعلام يقول لنا إجمالي 
ما دفعه كل أب مقابل الأصناف التي قام بشرائها لأطفاله. 


بعد حفظ الجدول ]| وإدخال البيانات السابقةء إفتح صفحة 
العلاقات» ثم إضغط بالزر اليمين للماوس في إي مكان فارغ وقم 
بإختيار (إظهار جدول) وأضف جدول ]| إلى صفحة العلاقات. 


في 18S SQ)‏ إذهب إلى وك۲4۳ وها وإضغط بالزر الأيمين في 
مكان فارغ وإختر ماطج ۲ ۸١‏ ثم أضف و" ]| إلى صفحة 
العلاقات. 


أريد من يقرأ معي أن يحضر فنجانا من القهوة أو الشاي» ويسن قلما 
من الرصاص ويفتح صفحة بيضاء جديدة في الدفتر ويعصر فكره 
کا ارو الأصناف ltems‏ 
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¢(¢666(66666666C6666CCG ۱١١١ا! تعذبو‎ 


تحیاتی»›»»› 


مرحباء»» 


وصانا (بعد التفجير الذي عطلنا والعياذ بالل) إلى كيف نربط و" ]| 
الجدول الجديد الخاص بالأصناف... 


نعود إلى مستر ل١00‏ للمساعدة... 
لنركز... 
الأطفال هم الذين يمكلون الأصناف وبالتالي الإستنتاج الأول هو أن 


جدول الآباء ليس له أي دخل في هذه العلاقة. العلاقة يجب أن تنشاً 
بین جدولي "6| و.80۸58 


إذا استعرنا ہں ]| من جدول |6۳١5‏ ووضعناہ حقلا غرییا 
في جدول الأبناء فإننا ننشىء علاقة واحد إلى متعدد (كل طفل لديه 
مجموعة من الأصناف) ولكننا نكون خلقنا مشكلة تكرار الأبناء لأن 
الطفل رقم 120 يحق له شراء أكثر من صنف وبالتالي إذا قام بشراء 
براية ومحاية قمنا بنتكرا رقم الطفل 120 وهذا مستحيل لأن رقم 
الطفل مفتاح أساسي. طبق على الورق لتفهم. 


إذا إستعارة ل ]| ووضعه في جدول الأبناء حل مرفوض. 
إذا استعرنا ہں S0‏ من جدول ئ80۸ ووضعناہ حقلا غریبا في 


جدول الأصناف فإننا ننشىء علاقة واحد إلى متعدد (كل صنف يملكه 
مجموعة من الأطفال) ولكننا نكون خلقنا مشكلة تكرار الأصناف لأن 
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الصنف رقم 91 يمكن شراؤه من أكثر من طفل وبالتالي إذا قام 
طفلان بشراء الصنف رقم 1 المسطرة قمنا بتكرار رقم الصنف 91 
مرحباً بك في عالم الضياع 


باءت كل محاولاتنا لإنشاء علاقة (واحد إلى متعدد) بين الأصناف 
والأبناء--- باءت إلى الفشل. 


ما هي المشكلة التي أمامنا؟؟؟ 
المشكلة تكمن في التالي: 


وفي نفس الوقت كل صنف يستطيع أن يمتلكه أكثر من طفل 


أي ان العلاقة من "٠s‏ ]| إلى 560۸5 هي واحد إلى متعدد 
وفي نفس الوقت العلاقة من 505 إلى |]6"s‏ هي واحد إلى متعدد 


إذا كانت العلاقة (واحد إلى متعدد) في الإتجاهين فإن العلاقة تصبح 
(متعدد إJ‏ nتعددNany Many 1o‏ ( 


مرحبا بك إلى هذا النوع من العلاقات.... 
في علاقة (متعدد إلى متعدد) ربط الجدولين ببعضهما البعض ---- 
ركز --- دقق - افتح عينيك س 


مهما حاولت أن تربط بين جدولين بعلاقة (متعدد إلى متعدد) فلن 
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تستطيع والسبب أناك ستضطر الع الغاء المفتاح الأساسي في أحد 
الجدولين للسماح بالتكرار (للمتعدد) وهذا ينسف تماسك وتكامل قاعدة 
البيانات. 


إا ماهو الك 


ألوووو -- مين معي على الخط --- مستر ل000 مرحبا --- ما هو 
الحل... 


الحل : إنشاء جدول تقاطعي -- ٥اط‏ ھ۲ ٥٣۸‏ اعم ںل شکرا مستر 
Codd‏ 


أهلا.... ما هو الجدول التقاطعي؟ --- إستخدم الدفتر 


أولاً ما معني --- ٥0‏ لل في سكك الحديد هناك دائما محطات»› 
هذه المحطات س 5 بتغيير | ت الحديد للإتجاه الى ® 


جاءت فكرة التقاطع لهذا العالم الفذ. 

عندما تصطدم بجدولين العلاقة بينهما في أي إتجاه هي علاقة (واحد 
إلى متعدد) تكون أمامك علاقة (متعدد إلى متعدد) وللربط بينهما تقوم 
بإنشاء جدول جدید يسمى بجدول التقاطع أو 6ا۲2 Junci٥۸‏ 


رل قاط هر من ال الذارل طا را با :الا 
الأساسي من الجدولين: 


الجدول و" ]| مفتاحه الأساسي 0ں N‏ ]| نقوم بإستعارته 
الجدول $0۸5 مفتاحه الأساسي ۳ل ۸N‏ 80 نقوم بإستعارته 


أنشأً جدولا جديدا فيه الحقلين التاليين: 
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2صن|اtemNum‎ 

iSonNumنص4‏ 
ماذا ینقصنا الآن؟؟؟؟ من یجیب؟؟؟ صح؟؟؟ --- لا يوجد جدول بدون 
مفتاح أساسي!!! 


آها... 
مغعمممممممممهممح 


إذا جعلنا ]| هو المفتاح الأساسي فلن نستطيع أن نبيع 
مسطرة لاکٽر من طفل 

وإذا جعلنا لله هو المفتاح الأساسي فلن يشتري أي طفل 
باق لفل 


نحم مخمو ع الخقين هن المفقاح الأساي... 


نشط کلا الحقلین ہں عا و SNN um‏ واضغط علی المفتاح 
الأساسي 


"بهمس وبصوت خفيف --- هناك مشكلة --- بعدين.. 
الأن أحفظ الجدول بإسم ك "ائم وتعالو بنا نربط هذا الجدول 
في صفحة الحلاقات بإستخدام الزر اليمين أضف الجدول 


teM58ا0ns‏ إلى صفحة العلاقات 
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زک 


من جدول الأبناء سحب ٥ں‏ 80۸ وأسقطھ علی n‏ ںN‏ 80۸ في 


جدول ١٣۳٥ا۸s S0٥‏ تم ضع صح علی التکامل وصحین علی کل 
من التعديل والحذف. لاحظ شكل العلاقة في أسفل الصفحة ---- نعم 


هي واحد إلى متعدد. 


من جدول الأصناف إسحب mہں nN‏ م†| وأسقطھ علی Item Nun‏ 


في جدول ۳٣١‏ ا٤80۸‏ ثم ضع صح على التكامل وصحین على 
كل من التعديل والحذف. لاحظ شكل العلاقة في أسفل الصفحة ---- 


نعم هي واحد إلى متعدد. 


واجب منزلي.... 


هل نستطيع تكرار رقم الإبن في‌ء "6ای" مS‏ ؟ لماذا؟ 
هل نستطیع تكرار رقم الصنف في" ع†ای"هS‏ ؟ لماذا؟ 


من يقول لي ما هي المشكلة الآن؟ 
اين العباقرة الذين سيحلون هذه المشكلة؟ 


فکروووووووووووووووووو وتعدبوووووووووووووو 
ملاحظة للاخ ------- :لم أفهم عزيزي ماذا قصدت بهذه الجملة 


(ولماذا نضع جدولين العلاقه بينهما هي 0۸6 0 0۸6 والسبب هي 
كمسالة أمنيه لحفظ البيانات الذي اعرفه ان العلاقه هي التي تفرض 
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نفسھا فلایمکن ان نجعلھا ٥٣٥ ٥ ٥۸6٥‏ الا اذا كانت کكذلك) 


قاعدة البيانات وقد شرحنا في أحد الدروس اننا نستطيع تغيير هذه 
العلاقة ما عدا (متعدد إلى متعدد) عندما نشاء متى ما نشاء كيفما 
نشاء. أوضح لي قصدك . 


مرحباء»» 


اشكر الاج ) ------- ( الي قام بتصحييح عدد e‏ -- نعم خطا 
مطبعي» آما إستحداث حقل اسمهھ ۸ں ٥ ٣N‏ ]ا0۸ فطبعا خطا لان 
هذا لا يتبع قانون كيفية ربط علاقة (متعدد إلى متعدد) 


طبعا مشكلتنا الان هي ما طرحه الأخوة جميعا وهي عدم القدرة على 
شراء صنف رقم 91 وهو المسطرة من نفس الطفل صاحب الرقم 
0 متلا. وهذا هو أجمل ما في العلاقة (متعدد إلى متعدد) والتي 
تتيح إنشاء جدول على شكل جسر أو تقاطع من خلال جدول جديد 
اسمه جدول التقاطع اط۵ ۲ ٥٠۸‏ امال » بعبارة أخرى لدينا جدول 
جديد نستطيع أن نفعل فيه ما نشاء. 


مرة أخرى (من قال أن جدول التقاطع يقتصر على الحقلين الغريبين 
فقط) ؟؟9؟!!!! 


فاون عند تشه الق و الخضائض تتحرل الععلة برمتها إلى (مخرد 
عد) فقط. 


أي أن الطفل هو نفسه والمسطرة هي نفسها --- لم تتغير الخصائص 


وبهذا يكون أفضل الحلول هو القيام بعد الأصناف --- بإختصار الحل 
هو الكمية. 
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أضف الحقل التالي إلى جدول التقاطع:s"عاs S0‏ 
¥ رقم 
إحفظ الجدول 


ما الذي حدث الآن... عند شراء أي طفل لأي صنف نضع كمية 
الشراء 


قم بإضافة السجلات التالية إلى جدول التقاطع: ٨s‏ ء†ائرSo‏ 
3 90 110 

11091 2 

11092 7 

110 95 5 

110 999 

120 93 6 

120 99 2 

130 90 2 

130 94 2 

130 97 4 

170 92 12 

حيث يمثل العمود الأخير الكمية المشتراة من كل صنفرQ‏ . إحفظ 
الجدول. 


أين نحن الآن؟ وماذا إستفدنا حتى تاريخه؟ 
كل الموضوع يتعلق بتماسك وتكامل قواعد البيانات 
النماذج والتقارير والمايكرو في الأكسس هي للعبث وإضاعة الوقت 


حتى لغة البرمجة المرتبطة فيها والتي تسمى ۷/8۸ أر sومعA‏ 
6هي مجرد عبث وهي لغة مشوه جدا من لغة البرمجة۷8 
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أن برامج قواعد البيانات المتقدمة (المعتمدة على خادم S۷6"‏ ) 
مثل SQL s Oracle‏ 5 لیس فیها لا نماذج ولا تقاریر ولا 


ان التماسك والتكامل يخضع إلى قوانين محكمة تساعد في إنشاء 
7اا 5kاو‏ الهيكل العظمي او الخرساني لقاعدة البيانات بشكل 


أن عملية ربط الجداول (ليست نزهة) تتم في دقائق. والغريب أن 
معظم من قابلتهم في حياتي المهنية يصرفون %10 من وقتهم على 
بناء الجداول والإستعلامات و90 لألوان النماذج والتقارير 
وتحريكها وترقيصها وتدليعها وتسطير ها --- غريب!! 


لقواعد بيانات من الوزن الثقيل والتي يمكن أن تباع في السوق يجب 
للباقي من الزبرقة والبهارات والنماذج وغيره. 


أن العلاقة بين الجداول دائما غير واضحة في البداية ويمكن تشكيلها 
بعدة طرق وعدة حلول» ومن هنا جاءت فكرة (فريق العمل) عندما 
تقوم بتصميم قاعدة بيانات فإنك تعقد سلسلة من الإجتماعات ينصب 
معظمها على الجداول والربط والإستعلامات وتظل تدور في هذه 
الظفة خئى تشنمن ناسك ر امل اة 


إستعلامات بالدرجة الأولي» والإستعلامات معقدة جدا إذا كان تصميم 
الجداول بطريقه سهلة وواضحة. 


إرجع إلى ملاحظتي للاخ (-----) في بداية هذا الدرس --- ببساطة 
قلت له خطا (وريحت دماغي واعصابي) أماذا؟ لا ارید ان افکر في 
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ES TS‏ أسهل ووأوضح وأفضل 


ماذا لو طلب صاحب قاعدة البيانات (التي نقوم بتصميمها له) أن 
يكون هناك حقل يوضح تاريخ الشراء للأطفال ؟؟؟؟!!!! 

في الحل السهل الذي قمت بإتباعة لم ألتفت إلى حل ( ت 
متلافيا صداعا وفكرا إضافياء لكن بإدخال (تاريخ لشراء) فإن هذا 
يعني أن الطفل سيشتري 10 مساطر يوم السبت و5 مساطر يوم 
الخد التكرار الان لا مفر تة اوسنكرن مشكلة خانفة تتظلب 
دعوة فریق العمل لإجتماع. لأنه في حالة ادخال تاریخ خ الشراء إنهار 
التماسك والتكامل وعندها نذهب الى الأخ ( ------) ونبوس راسه 
ونقول له (تكفى إشرح) مرة ثانية. عند إدراج تاريخ الشراء لا يوجد 
حل سهل سحري وسريع» ليس لدي حل جاهز... انا وانتم بحاجة إلى 
التفكير العميق الذي قد يؤدي الى إعادة تصميم القاعدة بشکكل مختلف. 
طبعا دائما وأبدا هناك حلول لأي مشكلة في قواعد البيانات. 


ما الذي أقوله؟ 


إن تصميم الجداول وربطها عملية في غاية التعقيد وقد عملت أكثر 
من تجربة في المحاضرات التي ألقيتها لأرى أن كل مجموعة تقوم 
بتصميم قاعدة البيانات بطريفقة مختلفة وكلها صحيحة ولكن الفروق 
تكمن في سهولة حل عن آخر»ء وكلمة سهولة تعني سهولة في إدخال 
البيانات سهولة فى إعادة فك وتركيب قاعدة البيانات سهولة في 
صيانة قاعدة البيانات وسجلاتها وحقولها. 


العملية ليست نزهة ... العملية ليست طبق من السلطة يحضر في 
دقائق مکونا من شوية حقول على کام إستعلام على شوية بهارات 
ماكروز على نموذج من هنا وتقرير من هناك. 


أخي ( SESE‏ ) سنعود إليك لتنقذنا فيما بعد عندما نفجر رؤسنا تفكيرا 
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في كيف نربط جداول قاعدة بيانات المستوصف. 


كان الهدف هو الحصول على المبلغ الذي دفعه كل أب مقابل 
مشتريات إبنه ولأن جدول الأصناف فيه ئم٥٤"‏ | كان 

بالضرورة وجود حقل يوضح الكمية لأ لضرب الكميتين 
والخضزل عل نكف الشراء 


صحيح أننا قمنا بعمل بعض الإستعلامات دون شرحها وهذا ما 
سنفعله الآن. 


ماذا سنفعل؟ 

سنترك الجداول والروابط ونعود إليها فيما بعد... متى؟ بعد أن 
نتحدث على واحدة من أقدم لغات البرمجة في العالم... وهي لغة 
SQL.‏ 


تحیاتی»»»› 


مرحباء»» 


ا فل لااب 


5Q‏ تعني Structured Query Langua 9e‏ وهي لغة 
برمجة قواعد البيانات ولا علاقة لها ببرنامج شركة ميكروسوف 
icr ost SQL Server‏ هي مجرد لقافة من شركة 
ميكروسوفت لإستعارة الإسم. 


إذا: 


4هي لغة برمجة 
SQL Server‏ 5هو خادم متقدم لقواعد البیانات صمم من 
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شركة إسمها ميكروسوفت و 1S‏ إختصار للكnlمMicrosof†.a‏ 


ومن هي عمتهاء حيث يعج الإنترنت بهذه المعلومات ويمكنكم البحث 
عنها بسهولة وقراءتها ونا أنصح بذلك متى تشاءون. 


التركيز على الحرف 4 حيث أنه هو المفتاح السحري للعملية كلها. 


Q = Query 


16¥ تعني إستعلام إستفسار إستفهام إستنباط إستنبطاااح ---- 
وصلت الفكرة؟؟؟ 


السرال اللديهى رالتقليدي هو ما الفرق بين الجدول والإستعلاء؟ 


الجدول هيكل خرساني شديد التماسك والتكامل يعمل مع بقية الجداول 
مع محافظته على استقلاله وشخصيته. الجدول هو رجل ببدلة رسمية 
منتصب الطول عابس الوجه لا يمزح ويسير في الشارع بجدية 
مفرطة وإلتزام كبير. 


لا تمزح مع الجدول... الجدول لا يقبل المزاح ول لا العبث ويغلب 
عليه التماسك والشدة والعبوس والتجهم. 


الإستعلام (ولد صايع) على رأي الأخوة في مصر ... حبوب» لذيذء 
يحب المزاح» سهل التعامل معه»ء يقبل كل أنواع المزاح والعبث ولكن 
إذا مزحت معه من (اليمين)» إذا مزحت معه من (اليسار) --- نسف 
قاعدة البيانات من جذورها. هل سمعت بمثل إتق شر الحليم اذا 
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غضب --- هذا هو الإستعلام!!! 


لأن السيد 0000 مزق حقولنا ووزعها في جداول مختلفة كان لا بد 
من طريقة ما لتجميع هذه الحقول مع بعضها البعض!!! 


جدا جدا في كيفية تشكيل الإستعلام. 


4هي لغة تستخدم علم (المصفوفات) من الرياضيات للوصول 
إلى الحلول --- ولا يهمك حقيقة ماذا تستخدم ولكن للعلم بالشىء فقط 
لمحبي هذا العلم الرائع المسمى المصفوفات هءاج ومفردها 


مصفو ف Matrix.‏ 


الغريب في 541 أنها عميقة الجذور وفي غاية التعقيد الشديد جداء 
ولكن الممتع في الموضوع أن كامل اللغة بكل أبعادها تتكون من أقل 
من 10 أوامر -- صدق أولا تصدق أو حتى أقل من 5 أوامر على ما 
أذكر!!! 


قلنا أن ا54 تمزح من الجهة اليمين --- وتغضب من الجهة اليسارء 
ما معنی هذا؟ 


هناك استخدامين اثنين فقط للغةَ ]©5 و احد أسميه مزاح من اليمي“ 
e‏ 3 ر 
والاخر مزاح من اليسار: 


الإستخدام الأول (مزاح من اليمين): هو الحصول على البيانات بأي 
شكل وبأي كيفية 

الإستخدام الثني (مزاح من اليسار) : هو تحدیث Skeleton‏ او 
الكل الرها ع الات و اشر ر ل اله لواد 
والروابط ---- اااووو خطير جدا!!! 
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الأكسس (بغبائه) وليتبع قوانين شركة ميكروسوفت في وجود برامج 
سهلة تشعر مستخدميها بسهولة قواعد البيانات وضعت لك برامج 
ضفر ة داخل الاكنسن تساعذك على ناء الجذارلء و رضحت 
صفحة تساعد غل إنشاء العلاقات»› ووضعت صفحة سهلة تساعدك 
على إنشاء الإستعلامات وهگڈا.. 


هذه البرامج الصغيره (في الحقيقة) مجرد واجهة بينك وبين 8Q1‏ › 
الذي يقوم بالعمل كله من ألفه إلى يائه هر اه8 


أشهر أوامر ا5۵ هو الإمر (إختر) أو إنتقي 7٥ع S٤1‏ 
يحتاج شرح هذا الأمر عدة أيام وعدة محاضرات ولكنني سأضعك 


على الطريق الصحيح للتعلم ثم تنطلق أنت. 


تركيب جملة 5٤1-01‏ يتكون من عشرات الأوامر الفرعية 
وآسهل شکل لها هو: 


Selecta 

بعدها فراغ أو مسافة 

بعدها إسماء الحقول مع وجود فاصلة بعد كل إسم حقل 
بعدها فراغ 

بعدھا کلمةہ م٣۴‏ 

بعدها إسم الجدول 


إفتح إستعلام جديد في قاعدة بياناتراأ ج۴ 
ستظهر لك نافذة تسألك عن الجداول التي تريد أن تستخدمها في 
الإستعلام 


إضغط إغلاق ©1٠50‏ بدون إختيار أي جدول... 
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من القائمة الرئيسية إختر (عرض ۷٥W‏ )ثم (عرض --- اSQ‏ ) 
ماذا تری؟ 

ترى جملة واحدة فقط وهي 1 )ع S٤]‏ 

إكتب الجملة التالية في السطر الأول 

Select FatherName From Fathers 


نفذ الإستعلام --- ماذا حدث؟؟ 


ليس هذا فقطء» بل من قائمة (عرض ۷1٥۷‏ )إختر (عرض 
التصمیم ۷٥W‏ 9۸ یم( )۰۰۰ مممممممم... 


ماذا تری؟؟؟ 
مرحبا بك في عالم الما Se‏ 


تحیاتی»»» 


مرحباء»» 


قلنا أن الأكسس ومتله ۱S SQ)‏ يساعدنك على إنشاء الجداول 
والإستعلامات من خلال برامج صغيرة --- نعم ركز --- فقط 
يساعدنك ولكن إنتبه مجرد مساعدة وليس حل كامل متكامل!!! 
ماذا يعني هذا؟ 


يعني أنك لن تستطيع الفرار من ا5۵ ولن تستطيع الهروب من 
تعلمها إلا إذا أردت أن تصمم قاعدة بيانات مبسطة لإستخدامك 
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إذا أرت أن تبيع قواعد بيانات 

ذا أردت أن تكون ضمن فريق عمل لتصميم قواعد البيانات 
إذا اردت أن تقبض نقود وتبيع للسوق 

إذا أردت أن تكون محترفا 


يجب أن تتعلم أوامر 5Q1‏ وإلا فإنك تضيع وقتك ولن تقفز حاجز 
المعلومات التي لديك»» بعبارة أخرى ستبقى معلومات تراوح مكانها 
وستصب جام غضبك على النماذج والتقارير والمايكرو التي تستنزف 
جهدا لا نتيجة ولا قيمة له. 


الجملة: 
Select FatherName From Fathers‏ 


تخضع للتركيب ×هأ"6۷ الذي شرحناه. 


Selecinأك‎ 

ثم فراخ 

ثم فراخ 

ثم کلمةہ٣ہ‏ م٣۴‏ 

ثم فراغ 

ثم إسم الجدول 

ماذا إذا كنت أريد أكثر من حقل -- بسيطة بين الحقول ضع فاصلة 
مثل 

Select FatherName, FatherNum From Fathers 


مستر C000‏ يصر على تمييز الحقول ويقول لنا حتى لا تتورطوا 
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فيما بعد في مشاكل كبيرة وكثيرة (قوموا بتمييز الحقول عن بعضها 
الخن) مادا نی هذا 


إفترض أن لديك جدولين مختلفين وفي كل جدول منهما يوجد حقل 
إسمه Father N2۳6٥‏ هذا يخلق واحدة من أخطر مشاکل قواعد 
البيانات والذي يسمى ۷†أناوأط"۸ ويعني الإلتباس والغموض. 
حيث لن تفهم 541 من أي جدول تريد بيانات الحقل 
FatherName‏ 


وبالطبع يستحيل أن يكون هناك جدولان بنفس الإسم في نفس قاعدة 
البيانات --- لنصحح ونتبع شروط مستر ه٥‏ 


Select Fathers.FatherName From Fathers 
Select Fathers.FatherName, Fathers.FatherNum 
From Fathers 


وضعنا إسم الجدول قبل كل حقل وبينهما نقطة. 

إعكس الموضوع في الآكسس أو ۱8S SQ)‏ قم بإنشاء إستعلام 

بالطريقة التقليديةء افتح إستعلام جديد» نقر مزودج على جدول 
۴6 إغلاق ثم نقر مزدوج على كل من الحقلين 
FathersNumeoĞFatherName‏ 

قم بإستعراض جملة )5۵ من قائمة عرض ۷ء۷ 

سترى نفس الجملة السابقة --- طبعا دعك من الفاصلة المنقوطة في 
نهاية الجملة --- لا قيمة لها الآن 


ماذا يعني هذا کله؟ 
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يعني أننا نستطيع إستغلال طريقة الآكسس وكذلك S|‏ ۸18 في 
إجراء الكثير من التجارب ومن تم الإطلاع على جملة 8S‏ وكيفية 
ترکیبها 


نترك قواعد البيانات كلها 


Operations‏ اArithmetica‏ أو العمليات الحسابية وهي عمليات 
الضرب والقسمة والجمع والطرح والأسس والوغاريتمات والجذور 
والمثلثات والفراغية والجبر و..ز إلخ 


Comparison Operators‏ أو عمليات المقارنة مثل المساواة 
وعدم المساواة وأكبر من واصغر من و...إلخ 


" أو العمليات المنطقية وهي" و" "أو" "لا‎ gicaا‎ Operations 
ğl}JAND, OR, NOT ... 


نعود إلى قواعد البيانات وهي تستخدم كل ما سبق من العمليات. 


طبق المثال التالي.. 

من خلال إستعلام اا كل الأباء من جدول الأباء وكل الأبناء من 
جدول الأبناء -- قمنا بهذا سابقا ولكن الآن أريد أن تشاهد جملة 
Select‏ 


SELECT Fathers.FatherNum, 
Fathers.FatherName, Sons.SonNum, 
Sons.SonName FROM Fathers INNER JOIN 
Sons ON Fathers.FatherNum = 
Sons.FatherNum 
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کل ما أریدہ منك هو الترکیز على الجملة ٣(‏ امل )|٣ ٣6۲‏ من یتذکر 
--- من يكتب معناء طبق النوعين الآخرين وشاهد تركيبة الجملة 
Left JoindlSsRight Join‏ 

تدريس 5۵1 والتي تحتاج إلى الكثير من الوقت والتمارين 

والتجارب والشرح المباشر. 


جملة 8۲ 0۸0۴۴ هي الجملة التي تساعد على ترتيب نتائج 
الإستعلام 


إفتح نافذدة استعلام جدبد في وضع SQL‏ واکتب الجملة التالية 


Select FatherNum From Fathers Order By 
FatherNum 


ماذا تعني؟؟ 
أظهر كافة بيانات الحقل ۳"8 4ل١۸6۲‏ ج۴ من ترتيب أو فهرسة أو 
(عرض التصميم) وشاهد كيف تم إنشاء الإستعلام بالطريقة التقليدية. 


كيف نستعرض السابق تنازليا 


Select FatherNum From Fathers Order By 
FatherNum DESC 


أنظر إلى الكلمة في النهاية م065 وهي إختصار ل 
es cen 14‏ اي تنازلي -- طبق وجرب وشاهد وأکتب 
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ملاحظاتك. 


ماذا لو أردنا كافة الآباء الذين رقمهم أكبر من 5000؟ 
نستخدم خاصية الشرط ۷1٤۸۴٤‏ آي عندما !!! ترجمھا كيف تشاء 
إ! 


Select FatherNum From Fathers WHERE 
FatherNum>50O000 


لاحظ إستخدم أحد (عمليات المقارنة) -- نفذ --- طبق --- شاهد--- 
فکر E‏ أكتب کے أخص والا لن تفهم شیئا.. . 


طبعا ستجد خطأ في الجملة السابقة ... لماذا؟ لأن رقم الأب (نص ( 
sT ext‏ 5000 رقم» تحدم الدوال -- وهي جزء من قواعد البيانات 
في الأكسس أسمها ۷۸1 أي عماج۷ أو قيمة» في MS S1‏ 
نستخدم وج أي التحويل. 


Select FatherNum From Fathers WHERE 
VAL(FatherNum)>5000 


ماذا لو أردنا أن نغير عنوان الحقل N2۳۳6‏ ام ط†۴a‏ لأنه باللغة 
الإنجليزية ونحن نريده بالعربية 


SS GG OT 


Select 
FatherName 
As 


]اسم الأبإ 
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From 
Fathers 
ASC 


٥!إختصار ۸5٥٥٣۵٣9‏ أي ترتيب أسماء الآباء من الألف 
إلى الياء. 
أريدك عزيزي القارىء أن تصرف وقتا لا يقل عن أسبوعين (فيما 


كل ما فعلنا حتى الآن هو المزاح الذي يتقبله 541 منا دون المساس 
كال رادت فا غ النذنات 


انوع الثاني من المزاح ينقسم إلى شقين: 


الأول: تعديل في البيانات داخل الجداول (في السجلات) -- وينبغي 
لكر 

الثاني: تعديل في الجداول والحقول والروابط بينها --- وهو الخطير - 
- وينبغي الحذر الشديد جدا 


تعدل بيانات الجداول يتم من خلال: 
اأضافة سجلات جديدة 

تعديل سجلات موجودة 

حذف سجلات موجودة 


تعالوا نستمتع بلغة )54 ونضيف سجلين جديدين لجدول الأباء 
نستخدم الأمر |١56۲‏ أي أدخل ولا تنسى عزيزي القارئ نحن 
نتحدث عن 560 وهي نفسها بالضبط (تفريبا) في كافة برامج قواعد 
البيانات مٿل الاكىس و Oracle MS SQL‏ ڍڪ Sysbase‏ 
وغیرها. 
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يا جماعة -- يا أصحاب الموقع --- لدي مشكلة في التحول بين 
العربي والإنجليزي -- عموما أنا غشيم في طرق المنتديات سأحاول 


Insert Into Fathers Values 


) 
1500 


39 
( 


نفذ الإسنعلام وتأكد من جدول الآباء أن الأب 1500 قد تم إضافته 


ومعناها اکل السجل التالي بالقيم الموجودة بین القوسين حسب 
ترتيب الحقول في الجدول... 


الإستعلامات» إذا حاو لت ا اض ا صنع هذا e‏ 


ات الان محر !ا 


تعالوا نعدل عمر الأب 1500 من 39 سنة إلى 36 سنة بإستخدام 
لغة SQ‏ 

Update Fathers SET FatherAge = 36 WHERE 
VAL(FatherNum)=1 500 


نفذ الإستعلام وقم بالتأكد من أنه تم تعديل عمر الأب 1500 من 
جدول الآباء 
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1500 تعال بنا نحذف الأب‎ 
Delete From Fathers WHERE 
VAL(FatherNum)=1 500 


نفذ وتاکد... 


واجب منزلي... 


بإاستخدام لغة 8S1‏ 


أظهر بيانات الأباء الذين أرقامهم أقل أو تساوي 4000 

أظهر بيانات الأصناف التي تكلفتها تقل عى 5 ريالات 

إسأل نفسك خمسة أسئلة أخرى على الأقل ثم حلها بإستخدام لغة 
SQL‏ 


تحیاتی»»»› 


مرحباء»» 


في لغة: 81 
عند الإضافة نستخدم 0| Insert‏ 


عند التعديل نستخدم ]ھ5 Update...‏ 
عند الحذف نستخدم ام0 


ركز معي مرة أخرى وتذكر دائما وأبدا أن هذه أوامر ا8۵ ولا يهم 
ال 541 من آين تستخدمهاء مين يتذكر الطبقة الاولى؟ 


في الطبقة الأولى (الخاصة بالنماذج التقارير) لا يهم من أين أتى أمر 
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اQسواء‏ من: 


VB 
VB.Net 
C#.Net 

++ÛC .net 


Java 
Access 
Excel 


MySQL 
Interdev 

Asp 
Asp.Net 


Oracle Designer 

إلخ... 

كل ما سبق يمكن أن يستخدم في إنشاء الطبقة الأولى وكل البرامج 
أاعلاهہ تستطيع التخاطب مع قاعدة البيانات (الموجودة في الطبقة 


الثالثة) SQL a‏ وهذا ممتاز ورائع لأننا لا يهمنا الأداة 


اشد نے فن SQL‏ كل قاعدة البياتات ويحتاح هذا إلى التدريب 
الا او ا 
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لإنشاء جدول جديد في قاعدة البيانات نستخدم الأمر عأCrea‏ 
Table‏ 
في إستعلام جديد أفتح (عرض-801) وادخل السطر التالي. 


4 
اأتس طط 
. 0 ا 


في آکسس 

Create Table Tests (TestlD text(4), TestName 
text(25), TestAge Number) 

والله مشكلة الأقواس --- تعبت انا من لخبطة العربي والانجليزي --- 
صلحو ها انتم!!! 


Query Analyzerمlختul,‎ [۸S SQL في‎ 

Create Table Tests (TestlD char(4), TestName 
char(25), TestAge int) 

صححوا الأقواس 


أذهب إلى الجداول وتمتع بالجدول الجديد !!! في NS SQ)‏ لا بد 
من عمل ۸ءم۲هR‏ للجداول حتى ترى الجدول الجديد. 


ستلاحظ أنك لا تستطيع تنفيذ هذا الأمر أكثر من مرة --- من يجيب؟ 
11 


لتعدیل جدول نستخدمعاطھ ۲ Alter‏ 
احذف جدول نستخدممااھ ۲ مہ5 


صدق أو لا تصدق عزيزي القارىء أن هذه الأوامر: 
Select‏ 
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Update 
Insert 
Delete 


Create Table 
Alter Table 
Drop Table 


هي فقط (تقريبا) كل أوامر لغة!!!! 8Q1‏ 

طا کا ف ف آلا ت كل مر هه لار ابر قفص رة وكا 
إلى الكثير من الصبر والجهد والتمارين والشرح وهاهنا أحاول أن 
اضعك على الطريق الصحب» إذا أردت الأجتراف فى كواعد 
البيانات لا بد من إتقان الأوامر السابقة. لاتيأس»» خذ كل واحد من 
الأوامر بروية وبهدوء وقم بعمل المئات من التجارب والمحاولات 
وما إلى ذلك... لاحظ في قائمة إستعلام Q6٣‏ في الآكسس سترى 
الكثير من أنواع الإستعلامات مثل: 


استعلام تحدیث 
استعلام انشاء جدول 


ل 


كل هذه الإسشعادمات يمكن نشار ها من خلال الأ ر امز الساقة 
وإستيضاح الفروق بينها في غاية الأهمية. 


لعل الوقت يسعفنا فيما بعد ونلقي مزيدا من الضوء على لغةاهS8‏ 
لنعود إلى قاعدة البيانات وجدولي الآباء والأبناء 
من ينشأً لي أستعلام سواء بلغة ا5۵ أو من خلال (عرض 


التصميم) يوضح إجمالي ما دفعه كل أب مقابل مشتريات إبنه؟؟ 
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قاعدة أخرى من قواعد السيد 0۵00© وتنص على أنه يمنع وضع أي 


مرة أخرى --- لا يمكن مثلا في الجداول أن تضع تاريخ ميلاد الإبن 
ثم تضيف حقلا للعمر تقوم من خلال البرمجة بطرح تاريخ الولادة 
من التاريخ الحالي وثم التحويل للحصول على عمر الطفل. 


عندما يقول 0000 ممنوع فهو يقصد أنك تستطيع عمل هذا ولكنك 
لن تحصل على قاعدة بيانات متكاملة ومتماسكة. 


كافة العمليات الحسابية تتم في الإستعلامات... 


E‏ السابق الذي وقفنا عنده نرید إجمالي المدفوع من كل 
أب مقابل مشتریات إبنه 


تعالو نری کیف يتم هذا... 


إستعلام جديد أضف الجداول كلها ثم إنقر نقرا مزدوجا على الحقول 
التالية بالترتيب: 
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من جدول الاباء: 
FatherNum‏ 
FatherName‏ 


من حدول الأبناء: 
SonNum‏ 
SonName‏ 


نفذ هذا أستعلام --- ما هي النتيجة؟ من يقول لي ماذا تعني هذه 
النتيجة؟؟؟ 


أرجع إلى التصميم بعد التفكير في السؤال السابق ومحاولة الحل 
وتعال نحسب تكلفة الشراء. 


لحساب كل ركز (كل) عملية شراء نضرب اءه ٣‏ ]| في الكمية 
المشتر اة Qty‏ 


في (عرض التصميم) للإستعلامات ستلاحظ أن السطر الأول هو 


۴|0 أي الحقل ونحن ليس لدينا حقل نحن لدينا عملية حسابية 


في عمود فارع اكتب: 
Qty*ItemsCost‏ 


لاحظ كيف يعدل الأكسس... 
الأسئلة إلا الذين لديهم كل ما عملناه على ورق!!! 


من قائمة (عرض ۷1W‏ )إختر مجاميع اهاه (ملاحظة 


(الاجماليات)) 
ماذا تلاحظ ؟ نعم أتت خدمة جديدة (سطر جديد) عنوانه (إجمالي) 
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وتحت كل حقل ظهرت جملة (تجميع حسب --- Group By‏ ) 
والمجاميع هي خاصية من أوامر لغة )60 وليس اكسس. 


جملة Group 8y‏ تحت N.۳٥‏ rعہا۴‏ تعني قم (ما استطعت) 
بتجميع الاباء المتشابهين اي لا تظهر الاب اکثر من مره. 


ولكن هناك (8۷ م6۲0 او تجميع حسب) تحت أسم الأب ورقم 


بالمناسبة العملية الحسابية هي حقل ويسمى Calcualted Field‏ 
أو الحقل الحسابي ومن هذا المنطلق لا نستخدم العمليات الحسابية في 
الجداول بل في الإستعلامات. 


الففتر جد ل اف الخفرل الخفة الن الا فى الاما اة 
اکت ار ا ا اه ا هھ ات 


مرة أخرى... 
نريد رقم الأب» إسم الأب» رقم الطفل» إسم الطفل» إجمالي تكلفة 


أعلم أن العملية صعبة شرحا بالكتابةء حبذا لو كنتم أمامي في قاعة 


تدريب لفتحت رؤوسكم (بسکكين خاص لدي) وصببت فيه المعلومات 
صا 


"= » 


عنه. 


لنكمل الإستعلام ثم نعود مرة أخرى ونحاول الشرح بشكل أكثر 
تفصيلا لأهمية هذا الدرس 
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إذا حاولت أن تقوم بالعملية (يدويا) فستلاحظ أنك ستضطر إلى إجراء 
عمليات حسابية جانبية لبعض الآباء --- لماذا؟ لأن (مثال) الطفل رقم 
0 ملقوف قام بإجراء أكثر من عملية شراء لأصناف مختلفة -- 
صح؟ 

نحصل على ... ماذا؟ 


الطفل 110 أجرى 5 عمليات شراء --- عند ضرب الكمية في سعر 
الصنف نحصل على ماذا؟ نعم ......... نحصل على 5 اجماليات 
نوضح اکثر 

الطفل الملقرف 110 


قام بشراء 3 محايات بسعر المحاية 2 ريال الإجمالي 6 ریالات 
قام بشراء 2 مسطرة بسعر المسطرة 4 ريالات الإجمالي 8 رباإال 
قام بشراء 7 أقلام ر صاص بسعر القلم 1 ربال الإجمالي 7 ربال 
E yT‏ 

وو او فر کل ل ون اااي 


المطلوب هو ما دفعه الأب ... أي اب الطفل 110 !!! ما هو؟ طبعا 
كلها هو ما دفعه الأب لقاء مشتريات إبنه 110 


أي هي ناتج جمع 6 و 8 و 7و ...و 


ن الحفل الحسابي الذي صنعناه هو عملية حسابية أريدك أف تختار 
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من القائمة وتستبدل (تجميع حسب) ب ۲65510۸ م×ع أي ناتج 


إذا قمت بتنفيذ الإستعلام الآن ستحصل على خطأ لأن الآكسس وال 
SQ‏ لن یستطیعوا عمل (تجمیع 8y‏ م ں٥6۲‏ )للعملیات 
بدون إستخدام قانون اخر للسيد 00۵٩‏ وهو 


Aggregate Functions‏ ر ل أعلم ترجمتھا بالعربیة!!! 


هل من يساعدنا بالترجمة... 


تحياتي»۰۰ 
مرحباء»» 


للأح الذي سأل عن (الكمية) أقول له الهدف هنا إجراء 
الحسابات وإذا قام طفل بإجراء عملية شراء لنفس الأصناف 
فهو مستحيل حسب تصميمنا للقاعدة (واللّه يا شباب كلمة 
القاعدة هذي تجيب الحساسية !!) وقد تطرقنا لهذا عندما 
إقترحنا أن يكون هناك (تاريخ الشراء) --- عند إضافة تاريخ 
الشراء يصبح تصممنا للقاعدة خطاً وبحاجة إلى إعادة 
التصميم بفکر مختلف و ورؤية مختلفة. 


وصIil Aggregate Functions JJj‏ وأشكر الأخوة على 


التركفة (ذواك الأعخواء) وامل أن تكون: هى :لر هة الدلهة :د 
ولا تھا هدا فالوا ترک ما ھی 
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لا تنس أن هذه الدوال خاصة بلغة ا54 ولا علاقة لما 
بالآكسس ... من يقول لي ماذا يعني هذا؟ وما آهمیيته؟ 


كل المعادلات الحسابية موجودة في هذه الدوال ومن 
اشهرها... 
--- A۷6وهي‏ المتوسط الحسابي وفي الرياضيات هو 


مجموع الأقيام مقسوما على عددهاعوةe۲ A۷‏ 


gagCount ---‏ العدد أي عدد السجلات في جدول ما --- او 
عدد الاطفال الإنات متلا 


Maxi Uma رoSÎMax‎ --- 

Minimumتaanaê‎ JêlMin --- 
Summationgge>aoJlSum --- 

E۷ ---‏ كاي الإنحراف المعيlري‏ ¬ټDeviati0 Standard‏ 
الخاص بالإحصاء 

وهکذا.... 


لحل الإستعلام الذي وقفنا عنده: 

نضع الحقول الأربعة التالية في الإستعلام ونختار من قائمة 
عرض (مجامیع اهاه ( 

۴atherNum‏ من جدول الآباء 

۴atherName‏ من جدول الأباء 

Um‏ 50NnNمن‏ جدول الأبناء 

sonNameمن‏ جدول الأبناء 


كل الحقول السابقة --- نختار لها إ8 مدآ أو تجميع 


ح سب 
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ثم نضيف الحقل الحسابي التالي في العمود الخامس 
ونختار له E×0۲855107‏ للكناية عن عملية حسابية 
sum([Qty]*[ItemCost])‏ 


صححوا الاقواس 


لاحظ أن إستخدام دالة --- 51۳ لن أجيب --- من يقول لماذا 
تم إستخدام دالة" Su‏ ؟ ما الفائدة منها؟ 


الصفحة الرئيسية _ إنشاء ‏ بيانات خارجية ‏ أدوات قاعدة البيانات 
! ۹ + 4 1 ب ت 
٠ ٠ ٠ :‏ : 
@ تمریري 
عرض تشغیل تکوين الحاق تحديت جدولي حتف إظهار 
ً جدول رکه تعریف بیاتات ول 
التتائح ١ع‏ الاستصللا 
كافة الجداول ج 31 × 
Father‏ 5 
Father‏ : جد ons Father‏ 3 
استعلام1 FatherNum‏ 
FatherName Sons‏ 
FatherAge EE:‏ 
اسنلا 
Items |‏ ج 
tems 3‏ : جدول 
اسنلا 
SonsItem‏ 
Sonsltem‏ : جدوl‏ 
استعلام1 
v‏ 
f *‏ _ 4 
احقل: 37 sum([ItemGost] *[Qty]) SonName SonNum FatherName [e]‏ 
lجد :Ja Sons Sons Father Father‏ 
الإجمالى: | تجميع تجمیع تجمیع تجمبع حسب Expression‏ 
قرز: 
إظهار: 5j i w‏ ا a a 1 0j‏ 
المعابير: 
و: 
| 4 


نوع آخر من الإستعلامات الهامة جدا ويسمى 25 1آككoاCr‏ 
اوهو عبارة عن جدول وكلمة جدول تعني صفوف 
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وأعمدة وعليه فان هذا النوع من الإستعلامات فيه تثلانة 
حقلين والثالث عملية حسابية» الحقل الأول هو صفوف 
الجدول. الحقل الثاني هو أعمدة الجدول. أما القيمة في 
تقاطع کل صف مع عمود. 


)من يساعدني في شرح كيفية إدراج صور في آي مشاركة ( 
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نفذ الإستعلام التالي: 


أضف جدولي الآباء والأبناء تم إختر من قائمة (نوع الاستعلام 
--- Query|ختر‏ (إستعلام جدوlلJي CroSSTab QU€FY‏ ( 


اضف حقل ع٥2۳١۲۸عطاج۴‏ من جدول الآباء --- الإجمالي 
(تجميع حسب) وجدولي (عنوان الصف) 


اضف حقل 50۸N3۳٥‏ من جدول الأبناء--- الإجمالي (تجحميع 
حسب) وجدولي (عنوان العمود) 


أضف حقل ١۳ا١ S0”‏ من جدول الأبناء --- الإجمالي (خ0اC0٤)‏ 
وجدولي (القيمة) 


نفذ الإستعلام... من يشرح لي هذا الإستعلام الرائع؟؟؟!!!! 
لا ینسی أحد منكم (رجاء لا أمراً) ان يصرف وقتا طویلا بل 
طويلا جدا في ممارسة الإستعلامات --- كل قواعد البيانات 


بعد تنظيم وإنشاء الجداول تعتمد على قوة ووضوح 
الإستعلامات. 
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وقبل الإستمرار في هذه السلسة من الدروس آمل من 
المع جل الواحت الثالى ناكد انك هعاك هن نذا كر واوك 


في قائمة إستعلام -- (وهي أهم قائمة) يوجد الخيارات 
التالية: 


استعلام تحدید --- QU r۷‏ )eع‌اعS‏ وقد قمنا بتطبیقه 
استعلام حدولي --- Q6۷‏ ۲055135) وقد قمنا بتطبیقه 
فقي المثال السابق 


إستعلام إنشاء حدول --- Make-1 abe Query‏ من يشرح 
لي هذا؟ 

إستعلام تحدیث --- r۷‏ عQu‏ عمل من يشرح لي هذا؟ 
إستعلام إلحاق --- Query‏ ۹ع‌ممA‏ من يشرح لي هذا؟ 

إستعلام حذف --- Qu‌er۷‏ اع من يشرح لي هذا؟ 


خاص ب ا5 أي خاص بلغة ا50 وفيها ثلاثة أنواع من 
الإستعلامات: 

U ۸10٩۹ توحید‎ 

Pass-1 hNrOUghéJ١رıرمت‎ 

Data Defi niti0 ^تٽا|نilaڊ تعريف‎ 


من يشرح لي ماذا يحدث عندما نختار أي من الثلاثة 
السابقة؟ لماذا يحدث هذا؟ 


قد يسعفنا الوقت لشرحها بالتفصيل فيما بعد. 
انتظر إجابات... 
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مرحباء»» 


قرر صاحب قاعدة البيانات أن يضيف جدولاً خاص 
بالزوجات!!!! 


تسانت هة بفنجان من القهوة وأعود بعد قليل وأريد 
(بمشيئة اللّه) أن أرى إقتراحات لحقول جدول الزوجات 
وكيف يتم الربط.. . لاحظ أن كل أب يمكن أن يكون لديه 
أكثر من زوجة... كما أن صاحب قاعدة البيانات يريد 
حقل لجنسية الزوجة. 


إضافة إلى هذا طلب منا صاحب قاعدة البيانات أن 
نوضح في جدول الأبناء جنس الطفل. 

لا تنسوا أن قواعد البيانات تصمم من قبل فريق 
فکروا... 

مرحباء»ء» 


إجابات رائعة من الأ (-) ما عدا جزئيات بسيطة»». 
وطبعا لا أدري من أين إقترح (جنسية) للطفل 6 
واللّه أضحكنى بشدة وهو يحاول إضافة جنسية للطفل 
٩‏ كيف يحدث هذا لا أدري... واضح أنه سريع 


القراءة. 
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اما إجاباته فهي أكثر من رائعة وينقصها ما يلي: 
في الإستعلامات التي تؤدي إلى حذف وتعديل 
وإلحاق سجلات لا يكفي رد الأخ --- (-) بالطبع رده 
00 0 ا و ا 


أن الحذف والإلحاق والتعديل ليس شرطاً أن يكون 
على سجل واحد. .. في إجابة الأخ (-) إستخدم ( =( 
في كافة الشروط W٤8۴‏ وهو صحيح إذا اردنا أن 
نصيف أو نعړرل أو نحذفی سجلاً واحدا فقط ولكن 
العملية أشمل من هذا حيث انه بتفيير العلامة ( =( 
إلى علامات أخرى مثل أكبر من وأقل من ولا يساوى 
السجلات من خلال تنفيذ امر إستعلام واحد. 


شكرا للأخ الصاحي معنا.() 


أضف جدول الزوجات W۷٥١‏ بالحقول التالية: 
NUm€Wifeنص‏ 2 --- مفتاح أساسي 
iWifeNameص‏ 

WifeAgeر‏ ةم 

WifeNationality ---‏ وهو موضوعنا الآن 

um ---‏ ۴atherNحقل‏ غریب للربط 


أضف الحقل التالي في جدول الأبناء: 
--- 50N5€Xوھو‏ موضوعنا الآن 


نعود للسيد --- C0۵0‏ ماذا يقول؟ --- أحد القواعد 
والقوانين العامة ينص على: 
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ماذا يعني تحييد اللغة --- يعني وببساطة شديدة 
عدم الإعتماد على ال في قاعدة البيانات» 
لماذا؟؟ 


لملايين الأسباب... 

تسهيل عمليات الإدخال 

تسهيل ترجمة قاعدة البيانات من لغة إلى أخرى 
تلافي أخطاء الكتابة والإملاء --- من يذكر مشكلة 
انتی وانثی وغیرها 

تصغير حجم قاعدة البيانات 


تعالوا نرى حقل الجنسية في جدول الزوجات... كيف 
نتعامل مع هذا الحقلء للأسف الطرق التقليدية والتي 
رأيتها في أكثر من قاعدة بيانات هي إدخال النص 
وحيث أن اللغة العربية من اللغات الغنية والثرية جدا 
في مفرداتها نرى انها أحد اللغات القليلة جدا التي 
نغامل کع صفات لا شی واکرک للذ گا انها من 
اللغات القليلة التي تتبنى مفهوم المثنى وغيره. 


نحمد الله أننا نتعامل مع جدول کله نساء الآن وبالتالي 
سیکون لدینا: 

سعوديهة 

كويتية 

قطرية 


مصريه 
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ولن يكون لدينا أبدا في هذا الجدول 


إذا مشكلة التذكير والتأنيث وجمع المذكر المعفوس 
(عفواء ترا أنا من أشد العشاق للفة العربية) ولكنه 


مجرد مزاح فقط... 


إنما لمشكلة ما زالت قائمة حتى مع كون الجدول 
بكامله يتعلق بنساء. ما هي المشكلة: 


سعوديهة 
سعوديه 
لاحظ (الهاء) مقارنة مع (التاء e‏ بوطة) --- في علم 
اغد المانات فا سن خسان مخلفیی:ء کف 


نضمن مدخل البيانات؟ كيف نحل هذه المشكلة؟ 
انفضا انی .مع الد 2 660 اغد ا گقى:. 


شكرا سيد --- 0۵٩‏ الحل هو بإستخدام الجداول 
nllسxclwةTables Help‏ 


والخذاول المساعغدة من احمل الخذاول الوا رك 


شر أخطاء الإملاء وتساعدك على تحييد اللغة 
بالكامل» والجدول المساعد تقتصر مهامه على تغذية 
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الحقول بالنصوص فقط وبهذا تكتب النصوص مرة واحدة 
لاء خت وك ولك هدا الملا ءال قت 
یله وو الک یں موکد دی کاو ردان 
الخو 


المشكلة الثانية التي تقوم الجداول المساعدة بحلمها 
هي عمليات التعديل» لنفترض ان لدينا في جدول 
الزوجات 2 مليون سجل منهم 100 ألف سعودية وتم 
إدخال الجنسية على شكل (سعوودية) خطاً ... ثم 
قررت تعديل هذا الخطأ... لديك حلان... 


إما إدخال يدوي وتعديل 100 آلف سجل يدوياً وهذا 
قطعا إنتحار... 

أو تصميم إستعلام ٥2ل‏ ملا لتحديث بيانات هذا الحقل 
وتغييره من (سعوودية) إلى (سعودية) ولكن لحظة... 


نحن مررنا مرور الكرام على هذا النوع من 
الإستعلامات ... الإستعلامات التي تؤدي إلي إلحاق 
وحذف وتعدیل لأكثر من سجل واحد تتطلب اعلی 
درجات الحذر وتتطلب إجراء نسخ إحتياطية للبيانات 
الأصلية قبل إجراء عملية التعديل لأن أي خطأً في 
الشرط WHE٤R۴٤‏ سیترتب عليه مصائب لا حد لها ولا 
حصر. 


أ كل الخكن الشايقن ( غير عملئ) والالى ا 
مفر من إستخدام الجداول المساعدة كعاطة٠‏ pام١۸‏ 
لفرل اللفة وتخبدها والخساقمة هئ النذانة قى انا 
قاعدة بيانات متكاملة ومتماسكة. 
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إنشأً الجدول المساعد التالي: 
Nationality NUmM‏ نص 2 -- مفتاح رئیسي 
iNationalityص‏ 


إحغفظa NationalitieSewl‏ 
أدخل البيانات التالية في جدول الجنسيات: 


ماذا نفعل بعد هذا؟ صح !! نربط جدول الجنسيات 
بجدول الزوجات ولكن يتطلب الأمر أولا تعديل الحقل 
if eNationa ty‏ في جدول الزوجات.... لیصبح ماذا؟ 


أجب قبل القراءة... 


نعدJ‏ |lحJa NationalityNum aJlJ| WifeNationality‏ 
على هيئة نص وبطول 2 ليصبح حقلا غريبا. 


إربط بین الحقلین Nati 0211۷ N10۳‏ بالسحب من 
جدول Nationalities‏ إلى جدول كمW۷i۷‏ وضع علامة 
صح على المربعات التلاتة... والعلاقة الآن واحد إلى 


منعدد. 


أضف السجلات التالية في جدول الجنسيات: 
2قطرية 

3كويتية 

4مصرية 

05|ماراتىة 

6يمنية 
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07عراقية 
8عمانية 
09بحرينية 
10سورية 


لاحظ أن التهجئة (الإملاء) للجنسيات غير مهم حاليا 
(تحييد اللغة) لان الربط يتم مع رقم الجنسية وليس 
النض هة التة تف 


قم بربط جدول الآباء مع جدول الزوجات --- قطعا لن 


ثم أضف السجلات التالية إلى جدول الزوجات:5عi۷‏ 
WifeNum WifeName WifeAge NationalityNum‏ 
FatherNum‏ 

0غادة سعید آل محمد 42 02 4000 

81منیى طلال خالد 22 10 4000 

82سارة خليل الدوسري 36 02 4000 

83مها عبد الرحمن الخليل 19 07 9000 

4سارة سعيد السالم 51 09 6000 

88عفاف محمد اليوسف 39 500001 


واحجب منزلي... 


کیف نربط جنس الطفل؟ ماذا يحل لنا من مشاكل؟ 
كيف نشا (ستتعلام بوصح عد الزوخات لكل أي وعدذ 
الأطفال؟ 

کم عدد زوجات کل أب من كل جنسية؟ 
فاط انول لک اوفط اغمار وات 
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اب؟ 


إسأل نفسك 100 سؤال وأجب عليها وإستمتع بقواعد 
البيانات!!! . 


مرحباء»ء» 


وصلنا إلى حقل جنس الطفل وسمى هذا النوع من 
الحقول (الحقول تنائية القيمة) أي لا يوجد إلا قيمتين 


ذکر 


وتستطيع عزيزي القارىء أن تطبق نفس الأسلوب 
الذي إتبعناه في حقل الجنسية في جدول الزوجات 
من حيث إنشاء جدول للجنس فيه حقلين رقم الجنس 
ونوعا الجنس وتربط مع جدول لابناء بحقل غريب هو 
رقم الجنس. وهذا مجهد لسجلين فقط (لاحظ ان 
جدول الجنس سيحتوي على سجلين فقط) وبهذا 
تصبح عملية إنشاء جدول وربطه وما الى ذلك مجهدة 
وا فا (للين غاا 

ف ال ا اة 

ذکر “ آنٹی 

ليل - نهار 

فترة صباحية -- فترة مسائية 

أو في حقول النفي والإثبات مثل: 
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متزوج -- عیر متزوج 
مدخن -- عير مدخن 
عصبي -- عير عصبي 
وهكذا... 


فاننا نستخدم حقول من نوع ا8 في ا@5 15 أو 
(نعم/لا ۲۵5/۸0 )في الآأكسس. 


ولكن الحقل في جدول الأبناء إسمه ×ع5صهS‏ متلا 
وبهذا تصبح الإجابة بنعم او لا غير منطقية وعليه جرت 
العادة إلى تغيير طريقة تسمية الحقل إلى شيء أكثر 
دقة مثل ان يكون إسم الحقل ٤ا2٣۴۴‏ وبهذا يصبح 
السؤال (انشتى؟) وعندها تصبح الإحابة نعم ام لا. 


وعليه لإستعراض الذكور فقط من جدول الأبناء يصبح 
الشرط هو: 

Female=no 

أي الجنس من غير الإناث. 


نترك الآن قاعدة البيانات الخاصة بالعائلة ونقفل 
الآأكسس أو أي برنامج قواعد بيانات آخر. 

وعلى الورق فقط (كتابة فقط) 

تل لی كق ذریط الکطاورل فى فاعةة الببانات الخاصة 
الست صف ٤‏ 


مرحباء»» 
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حرام عليكم ... وين الناس؟ وين الشغالين معنا؟ 
المهم أن نا الو ال وا این 
الهدف أن تكون الإجابة صح!!! 


ممتاز للأخ (-) وسؤال شخصي لك هل تعرف كل هذا 
مما سبق؟ إذا كنت جيدا في قواعد البيانات (مو 
الاكسس 2000 Microsoft SQا| Server‏ --- )وقمت 
بعمل آية مشاريع آو نماذج من قبل... آمل إرسال بريد 
إلكتروني توضح لي فيه خبرتك بالضبط وإذا كان لديك 
ك في المشاركة في مشاریع حقيقية. آمل ا 
ll‏ ا 
حالة قبولك ورغبتك ايضا) ستعمل من جهازك من 
منزلك ولن يؤثر عليك شيئا. بالعكس سيكون لديك 
دخل مادي جديد. تحياتي 


أتى وقت السحرر والأمساك ولم أقرأً أي إقتراح لكيفية 
ربط جداول المستوصف (بدون آكسس) على الورق 


انا بالإنتطا! !1111۱1 1111111111111 N1‏ ار... 


مرحباء»ء» 


مخاولة جندة نن الأ E‏ الس 


132 


اول ونى التاغة رو تاتف المكو و وة 


شأكون أول سبب من أنمباب تساقط الشعر لذيكم ... 
من كثرة التفكير والتمعن... 

يا ناس ... إتركوا النماذج والتقارير والماكروز --- ما يوجد 
في هذه الدروس هو ما یسمی بقواعد البیانات 


الباق مضغة لوقت 


سأنتظر.... وأستمتع وأنا أرى كل واحد منكم يتعذب 
في حل المشكلة!!!! 


مرحباء»» 
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الخ (-----) أقترح عليك القرآءة من البداية بهدوء 
وتمعن وروية.. نحن لا نتعلم الآأكسس هنا ... نحن 
نتعلم (مفاهيم وأسس قواعد البيانات) ... الحل الذي 
إقترحته هو من ناتج عن تراكم الأخطاء في تعلم 
قواعد البيانات... إذا أردت الإحتراف والحصول على 
مبالغ مالية من قواعد البيانات أقترح أن تعيد النظر 
لتساعد نفسك على نسيان المفاهيم الخاطئة 
وإستبدالها بمفاهيم صحيحة. أما إذا كنت تريد قواعد 
البيانات لإستخداماتك الشخصية فقط أو لقواعد بيانات 
مصغرة للإستخدام من قبل عميل واحد فقط فلا بأس 
كل الطرق جيدة وصحيحة. 


ولأساعدك أكثر أقول لك -- إحفظ القانون الشامل 
التالي: 


Combo Boxessرwلl‎ pئlgق‎ 
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مربعات النص5ع×60 ۲٤×‏ 


وغيرها كثير من الكائنات --- إحفظ جيدا --- ليس لها 
أي علاقة بقواعد البيانات لأن هذه الكائنات تستخدم 
فقط في( الطبقة الأولى) وهي واجهة المستخدم -- 
نحن نتعلم الآن (الطبقة الثالثة) وهي 82)٤١‏ 
الخاص بقواعد البيانات. 


كافة الكائنات تستخدم على النماذج والتقارير وبهذا 
تصبح النماذج والتقارير والكائنات والماكروز في 
(الآكسس) لا قيمة لها على الإطلاق... أقصد بهذا 
ليست للمحترفين ولكنها جيدة ورائعة للهواة. 


أعد حساباتك مرة أخرى وهذه فرصة جيدة وثمينة إذا 
كنت مبتدئا للحصول على المفاهيم والطرق الصحيحة 
وليس تعميق المفاهيم الخاطئة. 
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مرحباء»ء» 


توقعت الحصول على محاولات أكثر لا أدري هل مع 
بعد الصداع!!! 


وحيث أني قطعت على نفسي وعدا بفض النظر عن 
أية عناصر أخرى فسأكمل وكل أملي أن أنال في هذه 
الأيام والليالي الفضيلة الدعوات الصالحة منكم. 


نعود إلى قاعدة بيانات المستوصف.. 


وآمل حتى في غياب المشاركات --- أن يكون هناك 
من حاول» وقد كنت متأكدآً أنكم لن تصلون إلى الحل 
ولم يكن أصلا الوصول إلى الحل هو الهدف --- الهرف 
هو تعميق مفاهيم وأسس قواعد البيانات من خلال 
توضیح: 


أن تصميم قاعدة بيانات ليس نزهة ورحلة ممتعة 
وسهلة 

ان التصميم يتطلب فكرا وجهدا وفريق عمل 

ان تصميم كل قاعدة يختلف جذريا عن تصميم قاعدة 
بیانات أخری --- حيث أن لكل قاعدة بيانات شخصية 
مستقلة ومنفردة عن أي قاعدة آخری 

أن قاعدة البيانات الواحدة أي نفسها يمكن تصميمها 
بعشرات الطرق المختلفة ودائما يوحد طريقة مثلى او 
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أفضل من الطرق الأخرى. 


في جداول قاعدة البيانات الخاصة بالمستوصف لدينا 
مشكلة -- تعالوا نلخص هذه المشكلة: 


بين العيادات والأطباء -- علاقة متعدد إلى متعدد حيث 
ان کل عیادة یدخلھا اکثر من طبیب وکل طبیب يیدخل 


بين العيادات والمرضى -- علاقة متعدد إلى متعدد 
حيث ان كل عيادة يدخلها اكثر من مريض وکل مريض 
يزور اكثر من عيادة؟ 


پين الأطباء والمرضي -- علاقة متعدد إلى متعدد حيث 
ان کل طبیب یعالج اکثر من مریض وکل مریض يعالجه 


باختصارء العلاقات بين الجداول التلاتة هي علاقة 
متعدد إلى متعدد» ماذا يعني هذا؟ 


يعني (حسب ما تعلمناه) إنشاء تلاتة جداول على 
شکل ۴اط ۲2 ۸٥'ااcمuل‏ حجداول متقاطعة وھذا غیر 
عملي وسيؤدي إلى قاعدة بيانات على شكل 
(سباجيتي) أي متداخلة بشكل خطير مما سيؤثر 
على التماسك والتكامل. 


بالمناسبة المصطلح )»وهم سباجيتي (أي 


الهكرونة المت اخله) هو مصطاح على س كدر قى 
النرمحة. 
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ما هو الحل إذا؟ -- إتصال دولي سريع مع السيد 
0d ---‏ الإجابة هي باستخدام جداول الحركة 
Transaction Tables‏ 


معظم اعد العانات نخدم خداول الجر كة + تال 
نعود إلى (المنطق) ولننسى قواعد البيانات لدقيقة: 


لدینا مستوصف جدید (تم |فتتاحه منذ 5 دقائق) ولدینا 
جدول على الورق فيه بيانات الأطباء ولدينا جدول آخر 
على الورق فيه بيانات العيادات --- المستوصف جديد 
(اي لا یوجد مرضی( 


نحن جميعا في قاعة الا سال مبتسمين طا 


نعم -- صح -- ننتظر دخول مریض ما !!! بدون دخول أي 
مريض إلى المستوصف سنبقى جميعا في قاعة 
الإستقبال مبتسمين ننتظر حتى نهاية الدوام -- 
بالتعبير العلمي لا يوجد حركة في المستوصف!!! 


حتى لو دخل مريض (ولا يشكو من علة) فقط للإطلاع 
على جاهزية المستوصف وقام بفتح ملف (مجاني ( 
لدا کی الامفکووت تم کو که وا الک جا 


كل ما حصل أنه ساعدنا في إنشاء الجدول الثالث 
(جدول المرضى) حيث قمنا بإدراج بياناته في الجدول 
(على الورق) -- هذا لا يسمى حركة -- لأن الزائر 
ليس مريض ولم يترتب على زيارته إشغال (تحريك) 
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الطنت ولا اشغال (رك) العادة: 


لنفترض أننا حصلنا على 1000 مريض كلهم ليسوا 
بحاجة إلى أي علاج سوى التأكد من جاهزية 


المستوصف وقامو بفتح ملفات مجانية لديناء حتى الآن 
لا يوحد حركة في المستوصف... 


نفس الوضع في حالة كون قاعدة البيانات لمحل شراء 
وبيع» حدول للاصناف وجدول للعملاء (فارغ) وحدول 


للبيع --- بدون دخول مشتري لن يكون هناك حركة!! 


قي البنك جدول العملاء وحدول الحسابات وحدول 


وجدول ... بدون دخول عميل ووضع نقود او إجراء 
عملية تحويل فلن يكون هناك حركة. 

في المدرسة جدول للمدرسين وحدول للفصول 
وجدول للمواد بدون وجود طلبة مسجلين بمواد فلن 
يكون هناك حركة. 


متى تبدأً الحركة ؟ 
متى تبدأً قاعدة البيانات في التفاعل والعمل ؟ 


من يجيب بعد هذه الإضاءة؟ 


مرحباء»ء 
---ر نستکما " 


نعم جداول الحركة واحدة من ))))))))))))). 
اھ م ))))))))))))))))) واخطر 
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الجداول في قواعد البيانات... 


مرة أخرى كقاعدة عامة (وليست شرطا حيث تخضع 
كل قاعدة بيانات لشروطها الخاصة) نقول كقاعدة 
عامة عندما تلاحظ كثرة العلاقات من نوع متعدد إلى 
متعدد فابدأً بالتفكير ومحاولة الهرب من هذه العلاقة 
باستخدام جداول الحركة. 


وجداول الحركة في أكثر من %90 من الحالات تكون 
عبارة عن جدول واحد فقط يقوم بربط معظم الجداول 


ولأن الحركة في قاعدة بيانات المستوصف هي ناتجة 
عن زيارة لمريض لطبيب في عيادة فإن جدول الحركة 
لدینا سنسميه جدول الزیارات. 


ننشاً جدول جديد باسم 5١0ء۷‏ وفيه الحقول التالية: 
(على الورق...) 


رقم المريض -- حقل غريب يمثل المفتاح الاساسي 
من جدول المرضی 

رقم الطبيب -- حقل غريب يمثل المفتاح الاساسي 
من جدول الأطباء 

رقم العيادة -- حقل غريب يمتل المفتاح الأاساسي 
من جدول العيادات 


وحتى لا يزعل مستر C000‏ فنضيف مفتاح أساسي 
للجدول السابق وهو.. 
رقم الزيارة 
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حلاوة وروعة هذا الجدول الآن انه يعطينا الفرصة 
لإضافة أية معلومات عن ماذا حدث في العيادة بين 
الللست والفر ن 


نستكمل الحقول... 

تاريخ الزيارة 

وقت الزيارة 

وصفة العلاج 

تاريخ الخروج 

وقت الخروج 

القيمة التي دفعها المرض 


خط ات كل الحقول الخدت عن موصو 
(الحرحركة) أي الزيارة ولا علاقة لها بوصف ِ 
المریض کطوله ووزنه وجنسه (هذه كلها موجودة اصلا 
تي جاول المرضى) ولا نخدت قن الطييت (جحضسية 
ما کی ول اطا 
وكذلك الفيى: نففيه طبن فلن العيادة 


ما اروع جداول الحركة في سهولة وحمال حلما 
للمشاكل المعقدة الناتجة عن الإسباحيتي الخاص 
بعلاقات متعدد إلى متعدد. 


ا6 تف ماو اول لی دوك ال که 


درحة حرارة المرض 
قياس الضغط 


اعراض المرض 
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كل شيء» يتعلق بموضوع الزيارة يسرد هنا 


مشكلة واحدة فقط في جداول الحركة --- وهي أنها 
تعتبر القلب النابض لأي قاعدة بيانات» أمثلة ... أذا 
فقدنا جدول الأطباء ماذا نفعل؟ بسيطة (نوعا ما) نزور 
الأطباء ونحاول إعادة إدخال بياناتهم. 


فقدنا جدول العيادات --- نلف وندور على العيادات مرة 
أاخرى ونجري حصر لبيانات العيادات 


فقدنا جدول المرضي --- لا بأس نحاول الإتصال بهم 
(او ننتظر زیارتهم) ونعید تجمیع بیاناتهم 


أما فقد جدول الحركة فيعتبر مصيبة يترتب عليها الطرد 
من الوظيفة وخسائر فادحة لصاحب المستوصف. 


دائما جدول الحركة هو أخطر الجداول على الإطلاق 
ويتوجب دائما إجراء نسخ إحتياطية لهذا الجدول 
وتحديد صلاحيات الدخول للمستخدمين ... بل أكثر من 
هذا في البنوك متلا والتي تستخدم برنامج قواعد 
يراها مدخلي البيانات توضح ماذا فعل كل مدخل 
بيانات في تعامله مع جدول الحركة... لأنه ببساطة 
شديدة لو كان الشخص الذي يدخل بيانات جدول 
الحركة في البنك فاسداً فسيمكنه بمتهى السهولة 
إضافة بضعة آلاف من الريالات لرصيد حساب صديقه أو 


الثمن المدفوع مقابل جدول الحركة (عندما يحتوي 
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على بيانات مالية) أو معلومات ذات سرية قصوى 
يتوجب أن يقترن بجدول الرقابة كعاbة۲‏ ام٣‏ امه التي 


سلوا السانات انما مخظ تك ورسة من قل مضهحد 
قاعدة البيانات. 


من يقول لي الآن كيف نربط الجداول الأربعة الموجودة 
في قاعدة بيانات المستوصف؟؟ 


مرحباء»ء» 


الخ (----) ... كل ما شرحناه هنا ينطبق على كافة 
برامح قواعد البيانات التي تم إصدارها بعد عام 1970 
ميلادية وكما شرحنا في بداية هذه الدروس أنها 


القسم الأول: قواعد بيانات لحفظ البيانات فقط بدون 
خادم Sever‏ مثل الاكکسس و FoxPro 9 CliD}€r‏ 
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القسم التاني: قواعد بیانات على شکل خادم S€۲۷۴۲‏ 
ومن أشهرها: 

Microsoft SQL Server 

Oracle 


Sybase 


لافقا هن لفحم الازك الى القمم الا تى لا نة 
هن هاا هة رفي الامو الافة ةا وف ها 


أن برامج القسم الثاني لا يوجد فيها مايكروز ولا نماذج 
ولا تقارير ولا شيء من هذا القبيل وقد تنبهت 
الشركات المصممة للبرامح الثلاثة إلى هذه النقطة 
وقامت باضافة بعض البرامح الإلحاقية التي تساعد 


في تعويض هذا الإحتياج مثل: 


Developer‏ ل وراکل 
MS SQLUEnterpise‏ .... 
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.... Sybase JDevelopment Tools 


وهذه برامج إضافية أو إلحاقية تتعامل مع الخادم 
الأشافنى سيط عغملات انشاء التقارير ونما دخ 
الإدخال والإستعلام. 


قبل الخوض في هذه البرامج (من القسم الثاني) لا 
بد من توضيح أهم فروق يميز هذه البرامج عن بعضها 
القن فقو ن ساطة دة ج غذد الس دهن 
الذين يستطيعون الدخول إلى الخادم (إلى قاعدة 
البيانات) في نفس الوقت وفيما يلي بعض الأرقام 
التقريبية وليس للدقة: 


الآكسس مثلا --- في حدود 10 شخاص 

5Q1 --‏ في حدود 30 إلى 70 ألف شخص 
-- ا في حدود 100 إلى 150 ألف شخص 
-- 5ybaseبالملايين‏ 
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ولهذا تجد ان إستخدامات 25€ط5۷ ليست شهيرة في 
التطبيقات الإدارية ويقتصر إستخدامها تقريبا على 
المنشاآت المالية الضخمة وأهم مستخدمين لل 
عمsةybكهي‏ البنوك. 


وعليه فإن القفز إلى 58ةط/5 ليس عملي على 
الإطلاق بالنسبة لنا... 


يتبقى لديك الإختيار بين 15S SQ]‏ و عا٤ة0‏ لشهرتهما 
الكبيرة جدا في بناء التطبيقات الإدارية ويوجد بينهما 
فرق بسیط جدا... 


أن معظم البرامج في السوق هي تطبيقات لشركة 
ميكروسوفت وعليه فان الإنتقال إلى 0۲2۴٤‏ سيؤدي 
إلى ضرورة مواجهة والتغلب على بعض المشاكل 
الناتجة من المؤامة ۷اااibiأaمmpدc‏ والدعم الفني 
Technical Support‏ 
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من وجحهة نظري أن ا5۵ 15 يوجد له في السوق 
کتب أکثر» يوجد له دعم فني عالي وسريع من قبل 
شركة ميكروسوفت ولا يوحد مشاكل في الموائمة. 


بناء على الإضاءات السابقة أرى والرأي خاص لكل 


شخص ويتبع ذوقه وطریقته في التعلم... 


تعلم الثلاثة مع بعضهما البعض عملية شبه مستحيلة 
وتستنزف طاقات وجهد وأموال لا داعي لها وعليه 
يتوجب الأمر التركيز على واحد منها فقط. 


صرف بضعة أسابيع للإطلاع على كل خادم من الثلاثة 
السابقة لتذوق كيفية عمله وتبيین نقاط قوته وضعفه 
(متثال 0۲21٤‏ أقوى من‌اS۵‏ ۷15) في نواحي الأمان 
والسرية مثلا وهكذا... كل الفكرة من هذه الخطوة هو 
کنر خا الخوف:والرهنة من هتو ارام اة 
والإطلاع على طريقة عملهم وستفاجأ ان التشابهه 
بينهم عالي جدا جدا. 
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بعد (بضعة أسابيع) من التذوق والمحاولة والتجربة يتم 
التركيز على واحد منهم بقوة وشدة (وهذا ما فعلته أنا 
مثلا) وقد إخترت ا5۵ 15 بعد إستنزاف دام لسنة 


تقریبا في تذوق كلا من 021€ و S¥b25€.‏ 


ولگن:.. 


مشكلة MS SQ)‏ انه لا يوجد معه أية برامج إلحاقية 
قوية تساعد على إنشاء نماذج الإدخال وتقارير الإخراج 
وغیرها وبرنامج ٤ءأ۲م‏ ها٤‏ الملحق به يساعد فقي 
عملیات أخرى ذات قوة عالية جدا مiٹJ User Defined‏ 
JiSgFunctionsلd Stored Procedures Ji‏ وقد 
نتطرق لها لاحقا عند شرح بضعة دروس عن تطبيقات 
قواعد البيانات على الإنترنت. 


التمن الذي ستدفعه مقابل إختيارك ا5۵ 15 هو تعلم 
لغة أخرى تساعد على بناء نماذج الإدخال وتقارير 
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الإخراج وأبسط هذة البرامج FrontPage lew,‏ و 
AP.Netلتطبیقات‏ الإنترنت و ۷8.۸6 لتطبیقات 
Server.‏ ientا€وستصدم‏ وتفاجأً عندما تری أن کل ما 
تعلمته في نماذج وتقارير الأكسس هو نفسه تقريبا 
موجود في هذه اللغات !!! وهنا تكمن روعة وقوة 
شركة ميكروسوفت في أن ما تتعلمه يفيدك دائما في 


مرحلة أخرى. 


يتبقى نقطة واحدة فقط لمساعدتك على إتخاذ القرار 
وهي أن الإنتقال من الآأكسس إلى ا5۵ 15 أو 
اليس نزهة على الإطلاق !!! هو أشبه بالخروج 
من غرفة دافئة رومانسية إلى عاصفة رعدية وتلوج 


هذه النقلة تتطلب تصميما شديدا وعرقا وتعبا في 
البداية وسهر ليالي وما إلى ذلك»» يجب أن تصبر على 
هذا الأرق والتعب لعدة شهور حتى تبدأً مرحلة 
الإنتقال وتبدأ في تذوق طعم وحلاوة هذه البرامج. 
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مرحباء»ء» 


نعم --- أصبح ربط الجداول الأساسية الثلاتة سملا 
للغاية الآن من خلال جدول الحركة الذي قمنا بانشائه 
وأصبحت كل العلاقة من النوع المفضل وهي واحد 
إلى متعدد. 


مازال لدينا الكثير ... بل الكثير جدا لتعلمه وشرحه... 
ولكن بدا ضيق الوقت يطبق على انفاسي بشدة ... 
حيث سأتوجه إلى مكة المكرمة غدا الخميس ويومي 
السبت والأحد سأكون في إجتماعات عمل في 
مدينتي الدمام والخبر لأعود إلى الرياض في نهاية 
الأسبوع القادم. 


سأحاول قدر إستطاعتي التواصل معكم ومع المنتديات 
الاخرى... 


ولكني سأقوم بالتركيز على أسئلة المسابقة التي 
طرحتها من قبل وكذلك على الوعود التي قطعتها 
على نفسي في مساعدة بعض الاخوة والاخوات 
على بناء بضعة قواعد بيانات. ولعل الله يسمل لنا 
إكمال هذه الدروس. 
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هذه الليالي الفضيلة والمباركة وبالذات في العشر 
الأواخر وليلة القدر دعوات صادقة من أعماقكم بالذات 
ال داو ا ا 


ملاحظة. 
طرح الاخ €۲ Nas‏ {nterneا‏ سوال ھو: 
لماذا أتعلم قواعد البيانات 


مرحباء»» 
أي جواب لا يكون على الصيغة التالية فهو خطأً %100 !!! 


أتعلم قواعد البيانات لتحقيق رافد مالي جديد» بعبارة أخرى إذا كان الهدف غير 
تحقيق مكسب مادي فنصيحتي التوقف فورا عن تعلم قواعد البيانات وعدم 
إضاعة الوقت. 


اذا الجواب الصحيح والوحيد هو تحقيق مكاسب مالية وأية أجابات أخرى لا 
معنى لها.. 


0. 


وحتى لا يغضب مني البعض مثل ما حدث في بعض المؤتمرات أ 


التالي : 
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شخص يريد أن ينال إعجاب زوجته أو أخيه أو يستعرض أمام إبن عمه أو 
صديقه» وهذه الشريحة أنصحها بإستكمال تعلم الآأكسس وكذلك وضع الأسئلة 
في المنتديات وخلال بضعة أسابيع أو شهور سيكون قادرا على إنتزاع 
الإعجاب من أقاربه ومعارفه من خلال ترقيص بعض النماذج وتلوين بعض 
الأزرار وطباعة التقارير المبروزة. قطعا لا أتهكم ولا أسخر وإتما من يريد 
الإعجاب من الآخرين (فقط) فهذا هدفه وهذا طريقه ولا عيب في هذا 
وصدقوني لقد رأيت الكثير من الأسئلة في منتدى الآكسس يسألون عن كيفية 
إقفال نموذج بشكل راقص أو تدريجي أو ... !!!!!!!!!! 


اسي ايضا من بر ي ان ال ر في الل عة 

اس ستثني من يريد أن يقدم الواجبات والإختبارات لينجح فقط ومن ثم ينسى أبو 
قواعد البيانات وأهلها وما أكثر وما أضخم هذه الشريحة. 

اس ستثني أيضا من يريد أن يصمم قاعدة بيانات تستخدم من قبل شخص واحد 
قط اكرز فخض و اذ فط لا آکتر 


كل من سبق أقول لهم إستمروا في تعلم الأكسس وإستمروا بوضع الأسئلة في 
المنتديات وستجدون الكثير من الإجابات ولا باس بدورة أو دورتين تدريبيتين 
مخفضتين لتأكيد المفاهيم الخاصة بالآكسس أو ما شابهه الآكسس وخلال فترة 
قصيرة ستتمكنون من تحقيق أحلامكم من خلال إنتزاع إعجاب الآخرين وقد 
تقفزون حاجزا واحدا ويفتح الله عليكم من خلال بيع برامج الإستخدام الواحد 
(أي من قبل شخص واحد) متل محل لتأجير الأشرطة أو محل لتأجير 
السيارات أو ما شابه ذلك (و طبعا هذا احتمال ضعيف) ولكن الإحتمال قائم أن 
تبيع برنامج أو إثنين. كما أن لدى هذه الشرائح فرص لتصميم برامج لطلبة 
الكليات والمعاهد مقابل مبالغ مادية او تقديم دروس خصوصية أو فتح موقع 
مبسط بإشتراكات لشرح قواعد البيانات لهم. 


آمل من الشرائح السابقة مغادرة قطار قواعد البيانات في هذه المحطة متمنين 
لهم رحلة سعيدة. 


الشريحة التي تريد تحقيق مكاسب مالية (حقيقية) الرجاء البقاء في مقاعدكم 
إستعذاذا للدنطلاق إلى المحطة الثالية 
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الاه أن نا الكثر ر لكر من لمات رة 


الرجاء ربط الأحزمة. 


تحیاتی»›»» 


مرحباء»» 


للمتابعين معنا والباحثين عن تحقيق مكاسب مالية أقول لهم» جهزوا قلم 
رصاص جديد ونبدأً بالكتابة مرة أخرى. 


سیکون الاکسس ومثله من البرامج Clipper gs FoxPro Jin‏ ڪ dBase‏ 
وغيرهم أدوات للتعلم من حين لآخر --- فقط أدوات للمساعدة على التعلم. 


في الدروس الأولية تحدتنا أنه لا يوجد شيء اسمه نماذج ولا تقاریر ولا 
مايكروز في قواعد البيانات وقمنا بالتركيز على العمود الفقري لأي برنامج 
قواعد بيانات وهو الجداول والإستعلامات فقط وطبعا هذا مشكلةء لأن قواعد 
البيانات بحاجة (فعلاً) إلى نماذج وإلى تقارير وخلافه. هذه أول مشكلة -- 
عفوا --- أول مصيبة وأول عقبة حقيقة في طريق الإحتراف. 


كيف نصنع النماذج والتقارير ومن أين وكيف؟ هذه الطبقة الأولى !! من 
يتذدکر؟ 


رفضنا الآكسس وغيره من البرامج المشابهة للمشاكل التالية: 
Scalability‏ 

Availability 

Simplicity 
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Server Oriented 
من یذکر ما سبق؟؟؟‎ 


و)زازاهاهء؟ وتعني قابلية القياس» أو القياس للتبسيط وهي تعني أن قاعدة 
البيانات تعمل بنفس الكفاءة ونفس القوة بغض النظر عن عدد الجداول أو عدد 
السجلات أو عدد المتعاملين مع القاعدة في نفس الوقت. والمصطلح من الفعل 
ماهءS ۲١‏ أي يغير المقاس متل المقياس المستخدم في الخرائط وغيرها. 


Availability‏ وتعني التواجد أي ا قاعدة البيانات دائما وأبدا متواجدة 
ومتوفرة ولا ينقطع الإتصال بها تحت أي ظرف وعليه إذا أراد صاحب 
لر لن و عن راع ار اضر فن لوقت ل 30 ن 
قاعدة البيانات متعطلة. 


Simplicity‏ وهي بساطة وسهولة التعامل مع برنامج قاعدة البيانات وهنا 
الاكسس أفضل بكثير من غيره» ولكننا سنضحي بهذه الميزة للحصول على 
ميزات أفضل. 


Server Oriented‏ أي أن قاعدة البيانات تعمل على شكل (بث) 

Br sting‏ للدخول إلى الخادم ولیس على شكل ملف منفصل كما هو 
الحال مع الآكسس. بعبارة أخری ملف «D8‏ وھو إختفصlر Microsoft‏ 
Data B6‏ عبارة عن ملف منفصل متل أي ملف آخر نصي أو وثيقة أو 

غیره يتعامل مع محرك ,اعم لتنفیذ أوامر 8Q1‏ بشکل مبسط ولا یعمل 
علی شکل ۲ع۲۷ع$ خادم. 


بعد تبسيط المصطلحات السابقة ننتقل مرة أخرى إلى درس قديم بدأناه في بداية 
هذه السلسة وهر معا و ۲مم نعيد مرة أخرى: 


هن هو الجهاز الذي يتعامل مع الطبقة الأولى ويحتوي بالدرجة الأولى 
على نماذج الإدخال والإخراج. 
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S؟Sعإ۷عإ هو الجهاز الحاوي لبرنامج قواعد البيانات على شكل‎ Serve 
وكذلك على قاعدة البيانات تفسها التي تحتوي على الجداول والإستعلامات.‎ 
ماذا يعني هذا؟‎ 


أن الخادم يستطيع أن يخدم أكثر من قاعدة بيانات في نفس الوقت ومن خلال 
تالحر ك 

وینطبق علی هذا 

Micrsoft SQL Server 


Oracle Server 
Sybase Server 


ولأن الخادم عليه قواعد البيانات فهو يمثل الطبقة الثالثة. 
كما قلنا سابقا دعونا من الطبقة الثانية حاليا. 


مرة اخرى... 


E a E ES gE 
وإنطلقنا‎ Availability Ys Scalability YY pey J aig Server pدlخ‎ 
إلى أنه يوجد في السوق 3 أنواع من الخادمات.‎ 


وقد شرحت الفرق بين الخادمات الثلانة في منتدى MS SQL Server‏ وأعيد 
هنا مرة أخرى» أهم فرق بين هذه الخادمات هو عدد مستخدمي الخادم في نفس 


اق 
مثال: 
عع عدد المستخدمين في نفس الوقت 15 تقريبا (وضعته هنا للمقارنة 
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MS Q1‏ بالمتوسط عشرات الآلاف مستخدم في نفي الوقت 
6 بالمتوسط بالملایین 


لاحظ أن في الأكسس عدد المستخدمين الزين يعملون على ملف M58‏ في 
نفس الوقت (أي قاعدة بيانات واخدة فقط) بينما في الخادمات الثلاتة فإن العدد 
سيوز ع على عدد قواعد البيانات الموجودة على الخادم. 


مثال آخر: إذا وضعت 290 قاعدة بيانات على خادم 1S SQ]‏ فإن عدد 
المستخدمين (في نفس الوقت) سيقسم على عدد قواعد البيانات وطبعا ليس 
شرطا ففى حالة أنه لا يوجد مستخدمين على 100 قاعدة بيانات متلا فإن العدد 
خض ا انات ال كر 


بعبارة أخرى في الآكسس نقيس على قاعدة واحدة بينما في الخادمات تقيس 
على عدد المستخدمين لطاقة الخادم نفسه. لا نحتاج أكثر من هذا ولن ندخل في 


تقنيات معقدة. 

الخلاصة هي ن الخادمات الثلاثة تدعم أعدادا هائلة جدا وكما ترى فان 

Sybase‏ يدعم أعدادا بمئات الألوف بل تصل ل الملايين ویستخدم فقط 
في البنوك بالدرجة الأولى. 

ذا Sybase‏ قوته في حجم المستخدمين وكذللك في نواحي السرية 


«Security‏ وطبعا أقترح عليكم جميعا بعدم تعلم 6ا2لS»‏ من يقول لي 
لماذ؟ أين الأذكياء؟ 


مستر عام ج0۲ يأتي في المرابة الثانية من حيث 86611٣۷‏ وعدد 


ويقع ا5 15 في المرتبة الثالثة. 
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من تختار؟ ORACLE‏ أو MS SQ)‏ ولماذا؟ طبعا تعلم الإثنین (عفوا) 
غباء إ!! حيث بتطلب الأمر احتراف أحدهما وأخذ فكرة عامة عن الآخرء 
ومحدتكم أحد هؤلاء الأغبياء حيث أضعت سنتين تقريبا وكانت غلطة. 


أنتظر إجابة على السؤالين المطروحين؟ 


ٍ_  ؟ال‎ ؟yطچ2ئsم لمادا‎ 
؟MS‎ SQL ei ORACLE رlتخi‎ Il 


أنتظر بضعة إجابات... 


تحیاتی›۰» 


مرحباء»» 


أشكر كلا من الأخ --- وكذلك الأخ -_- على تفاعلهما وردهما الرائع بل 
الرائع جدا. 


صحيح لن يتصل بك أحداً لتصميم قاعدة بيانات 28ر (إلا بمعجزة) 
وسبب ذلك Sybase jİ‏ تستخدم من قبل الشركات الضخمة لتصميم قواعد 
عند تصميم قاعدة بیانات لدباك اختياران لا ثالث لهما: 


الأول: تصميم قاعدة بيانات تخدم منشأة (شركة مؤسسة وزارة إلخ) واحدة 
فقط فمتلا بمقدورك تصميم قاعدة بيانات لشركة تأجير سيارات. في هذا 
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الإختيار أنت تصمم قاعدة البيانات لتخدم هذه المنشأة فقط, عندما تتصل بك 
شركة تأجير سيارات أخرى مختلفة فإنك تقوم بتصميم قاعدة بيانات أخرى 
مختلفة تصلح لإستخدامات هذه الشركة فقط. بعبارة أخرى أصبح لديك 
قاعدتين للبيانات كلاهما يعملان لخدمة شركة تأجير سيارات وقد يتشابهان 
في بعض المكونات ولكنهما يؤديان خدمات مختلفة تصلح لكل شركة على 
حدة. مثال هذا أن تفصل توبا أو بدلة أو فستان لكل عميل على مقاسه وحسب 
رغباته. هذا إسمه النوع المغلق. 


الثاني: تصميم قاعدة بیانات تصلح للجميع فتقوم بتصميم قأاعدة بيانات لتأجير 
السيارات وتعمل منها آلاف النسخ وتبيعها في السوق لكل راغب في الشراء. 
وهذا هو النوع المفتوح. مثل تفصيل ثياب وبدل وفساتين وتوزيعها في السوق 
وكل من يقوم بالشراء يجري بعض التعديلات 


يقومون بتصميم قواعد بيانات هائلة الحجم للمنشآت المالية في العالم بإستخدام 
8y‏ وعليه فإن أقصى امالك واحلامك في 26طر6 أن تصبح 
موظفا في أحد هذه الشركات وتصبح فردا في أحد فرق العمل لديها للمشاركة 
في تصميم أحد قواعد البيانات هذه. 


معظم (إن لم يكن كافة) قواعد البيانات في عالمنا العربي المستخدمة في 
البنوك ومؤسسات النقد وشركات الأسهم وغيرها تستخدم قواعد بيانات 


مصممة من قبل برنامج ٥ء2‏ طر5 وكذلك تم تصميمها من قبل شركات في 
امریکا واروبا. 


هذا من وجهة نظري الشخصية يغلق باب 26ط إلا من يريد منكم أن 
os E‏ 
مasط8y‏ فآمل منه أن يبدا في الموقع التالي "0ع.S/(256. WWW‏ 


الفرق بين ماع0۲ و اهS 18S‏ ما زال شاسعا وقد سألت هذا السؤال عدة 


مرات منذ بضعة سنوات في محفل رسمي وکانت الإجابات كلها ماعa©‏ 
دون تردد !! وحينها كان عامة0 عشرات الأضعاف متفوقا على MS‏ 
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ا من كافة الجهات ومع ذلك نصحت الحضور بالتوجه فوراً إلى 8S‏ 
SQ‏ وكانت علامات الدهشة بادية على محيا الجميع !!! 


حتى هذه اللحظة مازال ٥اعه0۲‏ أفضل من الناحية التقنية ومازال أفضل من 
ناحية 56٥٣١۷‏ ولكن شركة مايكروسوفت تتمتع ببضعة خصال تجعل من 
إقتراحي بإستخدام MS S1‏ مرجحا بشکل آکبر» فيما يلي بعضا من هذه 


أقتبس من الأخ -- -- سيطرة هذه الشركة على سوق البرمجيات 

قوة الدعم الفني لشركة ميكروسوف تفوق الدعم الفني ل هامج0۲ بمئات 
الأضعاف 

سرعة تطور ا5۵ ۸5 تفوق سرعة تطور ٥امھ0۲‏ بشکل کبير وسریع 
وأرى آنه خلال بضعة سنوات سيتفوق ا8۵ ۸S‏ على ٥ا٥0۲۵‏ وبشکل 
تكلفة إنتاج قاعدة بيانات بإستخدام ۸S 8Q1‏ أرخص بكثير من عاعج0©۲ 
ityاi Compa‏ أو التوافق بين البرمجيات يرجح كفة 08S SQ)‏ لتفاعلها 
من البرامج الشهيرة بشكل أفضل بكثير من ماج0 

سعر ترخيص ۱S S41‏ أقل بمراحل عديدة من ٥اcھ©0‏ 


وبالمناسبة فليس لي علاقة لا من قريب ولا من بعيد بهذه الشركات لأفضل 
أحدهما على الأخرى (وياليت كان لي هذا للحصول على نسبة مقابل هذه 
التوصيات !!!). 


وطبعا أعيد مرة أخرى وآمل التركيز أن كل ما نشرحه هنا ونتحدث عنه 
ينطبق على الخادمات الثلاث اlلشkيرة Syabse‏ ڍ Oracle‏ ڪ MS SQL‏ 
حيث أننا هنا نتكلم عن قواعد البيانات ولا نتحدث عن البرامج المستخدمة في 
تصميم وتطوير قواعد البيانات. 


الإختيار مناط بك في النهاية. أنت تقرر ماذا تريد أن تستخدم» وكل ما نقوله 
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كانت لدينا من السابق مشكلة وَاحدة فقط وهی كيف نقوح بإنشاء تماذج 
الإدخال والإخراج والخادمات لا تدعم هذه الخدمة. 


تنبهت الشركات الثلاث إلى هذه المشكلة حديتا (منذ بضعة سنوات) وكان 
قصب السبق لشركة هامج0۲ في إنتاجها برامج إلحاقية للمساعدة على إنشاء 
نماذج الإدخال والإخراج. 


وكقاعدة عامة فان هذه البرامج الإلحاقية من قبل الشركات الثلاث يوجد فیها 
الكثير بل الكثير جدا من التعقيد والمشاكل و ۷†أاأطأأةم ص0 أي التوافق 
كما أن معظم هذہ البرامج الإلحاقیة کان موجھا إلى 86۲۷6۲ ٣٥ا٥‏ ولیس 
إلى الإنترنت وهو درستا القادم بمشئية الله. 


خلاصة القول أن البرامج الإلحاقية لم ولن (من وجهة نظر شخصية) تحقق 
الأمل المطلوب منها لإنشاء واجهات إستخدام حقيقية (نماذج إدخال وإخراج) 
وعملية وعليه فإني لا أرى في هذه البرامج الإلحاقية أي مساعدة عملية 
لمتطلبات السوق. 


جهة أخرى لا تنسى أن هذه هي الطبقة الأولى. 


کک ا Sy‏ 


EE 
مرحباء»»‎ 


صفحة خاصة منفصلة فى الدة ان إسمه (المشاكل الأساسية 
في في الدفتر ضع عنو ) ( 
وسنسرد في هذه الصفحة كافة المشاكل التي نحتاج إلى حلول لها. 
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حتى هذه اللحظة لدينا مشكلة أساسية واحدة وهي كيف نصمم نماذج الإدخال 
والإخراج عندما نستغني عن برامج بسيطة مثل الأكسس وغيره ونتوجه إلى 
الخادمات .Oracle ı MS SQL Jîn‏ 


مرة أخرى... لا يوجد لدينا طريقة لإنشاء نماذج الإدخال والإخراج. 


عرد آل أك ارون اة تي ات د ا و ارك غي 


Client 
Server 


أول شي ... ۲٠6ا‏ عندما نسمعها أو نقرأها نتخيل الطبقة الأولى ويوجد 
فيها نماذج الإدخال والإخراج. 


٣‏ عندما نسمعها أو نقرأها نتخيل الطبقة الثالثة ويوجد فيها قاعدة 
(قواعد) البيانات (قواعد) لأننا على خادم. وقاعدة البيانات حسب ما تعلمناه 


نقطة أخرى في غاية الأهمية --- ركز --- لأء ركز بشدة» المسافة بين 
Client‏ و Server‏ هي آلاف الکیلومترات !!! 

سنتخيل أن جهاز 8ا موجود في شقة ما في عمارة ما في مدينة مكة 
المكرمة» و 56۲۷8٣‏ موحود في شقة ما في عمارة ما في مدينة لوس 
أنجلوس !! المسافة مين يعرف أكثر من 17000 كيلومتر !!! 


كذلك سنتخيل أن جهاز مدخل البيانات موجود في شفة ما في عمارة ما في 
مدينة دبي. 
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قاعدة البيانات على الخادم في لوس أنجلوس فيها جدول صغير ببضعة حقول 
وبضعة عشرات من السجلات. بمعنى آخر مدخل بيانات واحد يكفي. 


الأجهزة الثلاثة كلها مرتبطة بالإنترنت. 


مدخل البيانات في مدينة دبي (مع فنجان من القهوة) يدخل إلى جهازه ويقوم 
بإادخال بضعة بيانات إلى القاعدة !!! 


نرکز ... ما الذي حدث؟ 


لإدخال بیانات إلى قاعدة ما نستخدم الأمر ٥٣ا‏ ٤s6ہ|‏ (لا مشكلة إن كنت 
لاتتذكر فهذا ليس هو الموضوع)...نركز عندما يضغط مدخل البيانات زر 
الإدخال تحصل آلاف العمليات التي لا نراها!!! من يستطيع أن يتقعص 
(مغمضا عینیه) لعدة دقائق أنك أنت جملة أ 6ئم| وبعد إرسالك من خلال 
زر الإدخال بدأت رحلة شاقة أكثر من 18000 كيلومتر من دبي متجها إلى 
لوس أنجلوس !!! 


مدخل البيانات أرسل سطراً واحدأ عبارة عن جملة ۸56۲| لإدخال سجل 
واحد فقط في قاعدة بيانات بعيدة جدا... 


لا يوجد شخص في العالم (إلا قلة) يستطيع أن يحدد مسبقا رحلة هذه الجملة 
يستخدمها ١ك۸6۲٥ه14)‏ أكثر من المبرمجين والمصممين. 


نحن كمبر مجیين ومصممين ماذا يهمنا من هذه الرحلة؟ من يقول؟ 


يهمنا التالي: 
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سرعة نفاذ الجملة من الجهاز في دبي إلى كرت الموديم إلى الخط الهاتفي في 
دی ای المقسم في دبي إلى مزود الخدمة في دبي إلى ¥2yةW‏ 6اه الخاصة 
في دبي إلى أي كيبل بحري إلى أوروبا إلى الكيبل البحري في المحيط 
الأطلنطي إلى مدينة نيويورك إلى |۳١‏ إلى مقسم في لوس أنجلوس إلى . 

إلى ... إلى ... إلى كرت الشكبة في عمارتنا إلى الجهاز إلى قاعدة الانات 
إلى لف ... واووووووووو---إستراحة رحلة طويلة... 


قلنا ما يهمنا بالدرجة الأولى هو ((((سرعة)))) تتفيذ الجملة !!!! 
حتى السرعة غير كافية... 


في الإنترنت علم قائم بذاته یتطلب شرحا ثقافیا مستفیضا (وقد یکون أحد 
دروسنا یوما ما) وهو ۲٤٥۲/1۲‏ وهي أحد أهم بروتوكولات الإنترنت... 
مشكلة TCP/IP‏ الأساسية أنها ل تضمن نفل البيانات من جهاز لآخر حول 
الكرة الأرضية وعليه لدينا مشكلة جديدة وهي من يضمن أن السجل قد دخل 
في قاعدة البيانات... والغريب أن معظم مصممي قواعد البيانات لا يلتفتون 
لهذه النقطة !!!! 


نعود إلى صديقنا في مكة المكرمة وهو مجرد زائر يريد أن يطلع على بيانات 
القاعدة فيقوم بتنفيذ جملة )ءع1ع$ للحصول على بيانات ما... 


ركز معي مرة أخرى من فضلك... لنفترض أن قاعدة البيانات فيها إسم 
الموظف» إسم أب الموظف»إسم عائلة الموظف. 


سنفترض أن مدخل البيانات في دبي (موظف نشيط) وقام بإدخال 3 ملايين 
سجل قي قاعدة البيانات. 


الصديق في مكة المكرمة يريد أن يحصل على جدول مرتبا أبجديا حسب 
العائلة لكافة سجلات قاعدة البيانات... بسيط... ننفذ له جملة )ءم[عS‏ ومن ثم 
ا اح الاب بإاسم العائلة مع فراع بین کل منهما لیراه کإاسم کامل 
ونقوم بالتنفيد. 
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NS‏ ولكن لحظة ماذا حدث في هذا الجملة البسيطة 


أخونا في دبي كان لديه مشكلة السرعة وضمان دخول السجل في القاعدة بينما 
LG E‏ .. المصيبة هي أن هذا 
اتل اد لکرم وه عى حطر اف اة اع الات 
لماذا؟ لأن الصفحة في مكة المكرمة ستأخذ ما لا يقل عن نصف ساعة لتفتح 
!!! حتى مع سرعة إتصال عالية جداً بل سيقوم الأخ في مكة المكرمة بترك 
الموقع والذهاب إلى موقع آخر أسرع وأفضل من موقعنا. 


إذهب إلى 00طه۲ وفي خانة البحث إكتب ۲٥٠٣ء1[‏ وإنظر إلى الرقم الذي 
يوضح عدد النتائج ستجده أكثر من 160 مليون سجل» حتى في إتصال هاتفي 
بطيء جدا أرسل لك 160 0 مليون سجل في بضعة تواني !!! كيف 
a og E E NR Ek‏ 


من يقول لي كيف هذا؟ ولماذا؟ أين الذين يدرسون؟ 

يكفيني بضعة إجابات لأني واثق ان الدروس التالية ستجعل الكثير يعودون إلى 
ا و ی CT‏ 
حیاته!!! 

من یجیب؟ 

تحياتي»۰۰ 

مرحباء»» 


إستمروا في التفكير للحصول على إجابة السؤال السابق. 
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نواصل البحث في المشاكل... 


عندما تطلبك شركة ما لتصميم أي برنامج يتصل بقاعدة بيانات فهناك تلاثة 
إحتمالات لا رابع لهما: 


الإحتمال الأول: 

شركة في مدنية الرياض في السعوديةء يوجد فيها 30 حاسب آلي مرتبطة 
جميعها بشبكةء هذا السيناريو يسمى 1,4١‏ اي شبكة محلية. ببساطة شديدة 
تختار أي جهاز منها وتقول هذا هو الخادم امإم؟ ثم تختار جهاز آخر 
(حسب تصميمك) وتقول هذا الجهاز هر م )عه أي الرديف» في حالة فشل 
الخادم م $۷ الأساسي تنتقل العمليات إلى up‏ )ءه8 لحين إصلاح الخادم 
وبهذا لا يكون هناك إنقطاع. ثم تختار جهاز ثالث وتقول هذا هو الجهاز 
المخصص لنماذج الإدخال ويستخدم من قبل مدخلي البيانات» تضع الجداول 
والإستعلامات فل «Server‏ تضع النمادج غل جهاز الطبقة الأولىء ویتبقی 
لك 27 جهاز كمستخدمين. هذا السيناريو أو الإحتمال الأول يسمى اعم )ہ1 
لاحظ وركز إنترانت وليس إنترنت !!! 


الإحتمال الثانى: 

نفس الشركة السابقة قامت بإفتتاح فرع في مدينة جدة ويوجد في الفرع 15 
جهاز مرتبطين بشبكة محلية ...1,۸١N‏ هههههه--- أهلاً بك في عالم 
التوهان!!! هذا السيناريو أو الإحتمال يسمى ۷۸١‏ ومشكلته الآن تكمن في 
كيفية الربط بين الإدارة العامة في الرياض والفرع في جدة!!! والحلول ٠‏ 
المطروحة هي بإستخدم الخط الهاتفي (وهذا تخلف آسف حل يعود ألى 
عشرات السنين إلى الوراء) أو بإستخدام دوائر مؤجرة تسمى .55١‏ 


الإحتمال الثالث:. 
في مدينة لاهور في باكستان... الأن لا يوجد إلا حل واحد 
(إقتص داددي) وهو الإنترنت!! 
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لا تقلق !!! 


المشاكل الساغة ل نکل ا فها كيصممين لاغذ اليانات هذه مشاكل 
مصممي الشبكات... نحن نجلس في إجتماعنا نتلذذ بفناجين القهوة ونستمتع 
بينما مصممي الشبكات يتضاربون بالأفكار والأيدي ويناقشون الإقتراحات 
والطول الف ارط هة القركة 


دورنا وعذابنا يبدأ بعد تصميم الشبكة حيث أن برمجة وتصميم قاعدة البيانات 
يختلف جذريا بإختلاف شكل رطمهإعهمه1 للشبكة. 


كل ما يهمنا في هذه الموضوع هو سرد مشكلة أساسية أخرى وهي كيف نربط 
بين واجهات الإستخدام (الطبقة الأولى) وقاعدة البيانات (الطبقة الثالثة) مرورا 
بطبقة المنطق (الطبقة الثازهة) ليس الهدف هو الربط فقط ركز ..... الهدف هو 
الربط بطريقة إقتصادية. كل الناس يستطيعون أن يربطوا بين النماذج 
والقاعدة ولكن قلة ضئيلة جدا تستطيع عمل هذا بشكل إقتصادي. 


قدرتك على الربط بشكل إقتصادي يشكل الفرق الأساسي بين من 
N N Ta‏ الربط الغير إقتصادي مكلف 
وبهذا د اع البوركن اى ا ر ك ا ا ع ي الخصول 
تعالوا الدروس إيلاما وتوجعيا لكل من يريد أن يحقق مبالغ مالية من 
قواعد البيانات» هذا الدرس مؤلم بشدة وأعنى انه سيؤدي إلى أن نخسر 
مجمو عة أخرى كبيرة خشية إقتحام هذا العالم. 


أو لاء لتصميم الواجهات (النماذج والتقارير والإحصائيات) نحتاج الى أداة 
مختلفة تماما عن خادم قواعد البيانات» لماذا؟ لأن الخادم يعجز عن توفير هذه 
الخدمة ول الخادم مخصص فقط فقط فقط فقط للجداول والروابط 
والإستعلامات و(نقول فيما بعد). 


ماهي الأدوات التي يمكن إستخدامها لإنشاء النماذج والتقارير... السؤال بسيط 
للغاية والإجابة أبسط منه... الإجابة... أية لغة برمجة يمكنها عمل ذلك: 
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هناك آلاف البرامج والتطبيقات التي تساعدك على عمل هذا بل أفضل من هذا 


Cold Fusion 
FrontPage 
Dream Weaver 


ا 
والممتع جدا في الموضوع أن الآكسس يستخدم (جوجو) لن آقول ما هو جوجو 
!! وهي تساعدك بشكل كبير في إحتراف آي مما سبق. 


ولكن لحظة.... 

كل ما سبق هراء في هراء ومضيعة للوقت والغريب أن الكثيرين والكثيرات 
إرتدوا ملابس السباحة وقفزوا في بركة الفيجوال بيسك لينتهو بنفس العبث 
ونفس الضياع الذي إكتسبوه خطاً من الآأكسس. 


کل اللغات والأدوات السابقة لا قيمة لها بدون آداة صغيرة ولذيذة وخفيفة الدم.. 
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بعد هذه الرحلة من الدروس المتشعبة وصلت بك عمدا إلى حائط طويل 


وعريض»» لن تستطيع الإستمرار بدون قفز هذا الحائط.. أن شئت الإستمرار 
فقد حان الوقت لتعلم هذه الأداة» حبذا لو أننا جميعا في قاعة درس لشرحت هذه 
الأداة ووصلت بكم إلى حد الإحتراف في محاضرة واحدة مدتها لا تزيد عن 

أربع ساعات ولكني سأحاول هنا أخذ مفترق للطريق الطويل والشاق والإتجاه 
يمينا لشرح هذه الأداة بسرعة. 


الان انسی کل ما درسته في الحاسب الأليء إرمي قواعد البيانات كلها 


هيا بنا نقفز أول حائط في طريقنا... الأداة هي ۲M‏ ] 
وهي |ختصار Hyper Text Markup Language J‏ 


ورقة بيضاء جديدة وقلم رصاص مبري ومحاية ومسطرة وفنجان قهوة. 

ھيا بنا إJٴ‏ عل HTML‏ 

تحياتي»۰۰ 

مرحباء»» 

لکل من تعلموا وتعلمن H۲۷1‏ بالطرق السیئة متل طریقة eعے ٣‏ ٤۸٣٥إ۴‏ 
سنعود إلى عع ۴۲٥٣۲۴‏ ستروا أن العملية عندما تدرس بشكل منطقي وبفکكر 
مختلف تصبح اسهل واوضح و...و... 

أمل من المهتمين توجيه الأخوة والأخوات في منتدي الويب المشاركة معنا. 
لا يوجد صفحة من مليارات الصفحات على الإنترنت أو الإنترانت إلا وهي 


على شكل ۳1۷1 هذا كلام ممتع ويشعر بالغبطة والسرور. 
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ملاحظة أخيرة طرق البرمجة القديمة التي تسمى ٤11٥,1 $٥۷٥۲‏ والتي لا 
تعتمد علی ۲۲۷1 بشکل مباشر متثل ہو5 ۴٥۲‏ في آوراکل او 
النماذج في آكسس أو إئج8 اء¡ في 18S SQ‏ هي آخذة في الإنهيار - 
- تقنية (إلى حد ما قديمة) هذا الجيل (نقف له إحتراما) يتوجه الآن وبشكل 
مكثف إلى ۲۲1 » لماذا؟ ببساطة لأن تكلفة الإنتاج بإستخدام HTML‏ 
أرخض بمئات المرات من تلك البرامج وتكلفة الربط والصيانة أرخص. 


ولهذا ستلاحظون سواء الآن أو بعد عشر سنوات أني قفزت على حاجز 
التصميم بإستخدام تقنية إع Sv‏ "ع11٣‏ والذهاب مباشرة إJ١” HTML‏ 
وعندما يحاوركم شخص ما عن فؤائد التقنية القديمةء ليس عليكم سوى الإبتسام 
فقط (وعلى مسئوليتي الشخصية) قطعا لن يكون 11۷1 هو الأداة الوحيدة... 
ولكن الممتع هو أن كل اللغات تنتهي في آخر المطاف إلى [M1‏ وها نحن 
نتعلم H1‏ لنرى ما هي نهاية هذا المطاف. 


بإسم الحق نبدا... 


كافة ملفات 111 هي ملفات 1٠×)‏ أي نصية 

كافة ملفات ۳1M‏ تنتهي باإمتداد [اہ)ط. مثل [صاط.susu‏ 
كافة ملفات ا1[Mګ‏ تحتوي على علامات وم u)اه‏ وكل علامة تعني أمر 
من الاوامر 

كافة العلامات والأوامر توضع بين علامتي <> 

كل أمر من الأوامر (علامة) له بداية وله نهاية 

بداية الأمر على شكل <> 

ونهاية الأمر على شكل </> 

آنا گان کا فر سا اهن مهه ل۸56 

فتصبح البداية <medصAh>‏ 

</Ahmed> ةlilly‎ 


واضح... 
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أوامر 111 لا يمكن قراتتها وتفسير ها إلى من خلال متصفح ويوجد في 
العالم المئات من المتصفحات ولكن أشهرها إثنان: 


Microsoft Internet Browser 
Netscape Internet Navigator 


الأول من شركة مايكروسوفت وهو شهير في العالم العربي وآسيا 

الثاني من شركة نيتسكيب وهو شهير في أميركا وأوروبا 

لا تنسى ان كتابة الموضوع في عام 2003 

کل ملف ۲۲1[ يجب أن يبدا بالأمر <]۲۷][> وينتهي بالأمر 
</HTML>‏ 

ملاحظة العلامة / تكتب قبل الامر و عندما تلاحظها في الامثلة القادمة قم 
بتصحيحها كما في اعلاه 

في جهازك على سطح المكتب إنقر بالزر الأيمن وإختر ... لحظة .. لاتختر 


للذين يستخدمون الويندوز بواجهة عربية أي لديهم (إبدأً) بدلاً من ه6 أقول 
لهم إتقوا الله في أنفسكم... وإعملو الليلة على إعادة تنصيب الويندوز بواجهة 
إنجليزية (مع عشقي للغة العربية) ... من يريد الإحتراف ويريد مالا فلينفذ ما 
إقترحته فورا. 


بالزر الإيمن على سطح المکتب إختر Text Document ۃ¦î New‏ لإنشاء 
وثيقة نصية على سطح المكتب. لا تغير الإسم» إنقر نقر مزدوج لفتح الوثيقة 
النصيةء ثم من القائمة إختر ]۴1 تم ...ئ۸ م2۷؟» الآن ركز... 


في خانة مصهN ۴11e‏ إكتب اصاط. uu‏ ... لا تحفظ الآن ... لحظة 

في الخانة التي تحتھا ٥م‏ را یھ م۷هS‏ إختر ی٥۴1‏ ۸11 لتجنب الحفظ بإمتداد 
txt‏ 

أقفل الوثيقة... ماذا تلاحظ على سطح المكتب؟؟؟ 
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أخذت الوثيقة شكل علامة م الخاصة بمستكشف الإنترنت... نقر مزدوج على 
tn1ط.Kuku‏ وسيقوم المستكشف بفتح أول وثيقة إنترنت 11١1‏ لك. مرحبا 
بك في عpll HTML‏ 


في قائمة المستكشف إِضغط علی Ww‏ ع ]۷ تم lEڑJ Source‏ هذا الأمر يظهر 
لك محتويات الوثيقةء ماذا ترى؟ هههه !! نعم صفحة فارغة!! ماذا كنت تتوقع 
ا کے رف 


أغلق صفح SoUuICe‏ وأترك الأمستكشف مفتوحاً علی صفحتنا u)ں‏ ع اذهب 
پعدال , 


الأولی بالضغط علی u)ں‏ × بالزر الأیمن ومن تم إختیار طازسw 0e١‏ ومن 
ثم أختيار برنامج ل2م]هN‏ الذي ياتي مع ویندوز.. 


الثانية هي فتح أي وثيقة نصية ومن ثم الأمر ۴1٥‏ ثم مم0 تم إختیار ۸11 
ی تم إختیار u)ںk‏ من سطح المکتب. 


الان لدينا )ن مفتوحا كبرمجة في ل2م" ومفتوحا كعرض في مستکشف 
الإنترنت... 


في الوثيقة 1م٤ط.‏ نن نطبق الشروط أكتب الجملتين التاليتين: 
<HTML>‏ 
</HTML>‏ 


على سطرين منفصلين تحت بعضهما البعض»› الحروف الكبيرة والصغيرة لا 
فرق بینها. 

تم إضغط زر ۳5 لتحديث الصفحة» الان Ww‏ ع۷1 تم Source‏ ماذا ترى؟ 
ا ر ك 
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كل الأوامر في ملف H1‏ يجب أن تكون بين العلامتين <1 11> و 
</HTML>‏ 


انتهينا من القاعدة الأولى والثانية -- مرة أخرى 

القاعدة الأولى يجب أن تبدأً الوثيقة ب <11۷1 > وتنتهي ب </[3#1×M1<‏ 
القاعدة الثانية كافة الأوامر يجب أن تقع بين العلامتين M1‏ ١]؛‏ أي أمر 
خارجهما سيسبب الكثير من المشاكل. 

القاعدة الثانية-- وهي أمر الرأس وأمر الجسد 

علامة الرأس هي 18۸5 وعلامة الجسد 805۷ اي جسد الوثيقة أو 
المحتوى الأساسي وتكتب على الشكل التالي: 

<HTML> 


<HEAD> 
</HEAD> 


<BODY> 
</BODY> 


</HTML> 
من ضاع منکم؟‎ 
شرح سريع لما سبق...‎ 


بدأنا الوثيقة ب 1۲1 وأنهيناها بنفس العلامة 
ثم أمر الرأس وأقفلناه» ثم أمر المحتوى وأقفلناه 


ھم أوامر أو علامات الرس ھو أمر العنوان 11١۴‏ 
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و 
من الآن فصاعداً تتبع الخطوات التالية: 

تعدیل الو ثیفة ا ہاط. ku‏ ںK‏ تم تختار Save pۃڌû File‏ 

تم إِذا رغبت في ذلك الضغط ا View‏ ثم Source‏ لرؤية المحتويات 


فلل وان اة 
<HTML>‏ 


<HEAD> 
<TITLE> 
1 love HTML very much 
</TITLE> 
</HEAD> 


<BODY> 
</BODY> 


</HTML> 
لاحظ أن 1)1 يجب أن تكون داخل رأس الوثيقة له٥1]› اي شيء تضعه‎ 
بين بداية م1٤1 وإقفالها يظهر في أعلى صفحة المستكشف فوق في الأعلى‎ 
في الجزء الأزرق أمل أن تروه... قم بالتجريب والإستمتاع.‎ 
أية معلومات أو محتويات توضع في الجسد او المحتوى او ول8 وأشهر‎ 
٥م العلامات‎ 
وهي إختصار طمهإعهإه۲ أي فقرة..‎ 

<HTML> 


<HEAD> 
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<TITLE> 
1 love HTML very much 
</TITLE> 
</HEAD> 


<BODY> 

<P> 

Hello HTML pals and gals 
</P> 

</BODY> 


</HTML> 
قم بالتجريب...‎ 


الأان ركز معي بشدة... 
لكل علامة من العلامات (الأوامر) تعديلات ... ركز تعديلات... أو فلنسمها 
أوامر فرعية... اي أوامر تساعد على تعديل الأمر وتحسينه.. معظم الأوامر 
لها تعديلات وإضافات. 


كافة الأوامر الفرعية او التعديلات توضع في أمر الإفتتاح وليس الإقفال فمتلا 
مر Body‏ 

يكتب على شكل <5۲ 80> هذ أمر الإفتتاح وهو ما يمكن أن يحتوي على 
التعديلات أما أمر الإغلاق <۷ 805/> فلا يمكن أبدا أن يحتوي على اية 
SE‏ ۰ 


أين توضع التعديلات الفرعيةء مثال: 
<BODY lia>‏ 
تبدأً هكذا 


< 
BODY 
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لاحظ أن ما سبق هو أمر الإفتتاح... 

أشهر التعديلات على أمر رل8 هو لون الخلفية للصفحة... 
<Body bgcolor=blue>‏ 

عدل أمر رل8 حسب ما سبق وجرب... ماذا تلاحظ... 

الأمر الشهير الآخر وهو "ه۴ وله تعديلات كثيره أهما حجم النص لونه 
واسمه ويكتب بالشكل التالي 


>/۴٥⁄×N1<لكشب ويقفل‎ >FONT1< 


تعالو نعدل الأمر ۲ ونضيف عليه أمر ۴.۲ تصبح الوثيقة كما يلي: 


<HTML> 


<HEAD> 
<TITLE> 
1 love HTML very much 
</TITLE> 
</HEAD> 


<BODY bgcolor=blue> 
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<FONT face=arial size=30 color=white> 
<P> 

Hello HTML pals and gals 

</P> 

</FONT> 


</BODY> 


</HTML> 
جرب ما سبق...‎ 


لاحظ اننا فتحنا أمر رم۴ ثم فتحنا ۲ ثم أقفلنا ‏ ثم اقفلنا )۴ 


المزعج جدا في ]۳1 انه لا يوجد أخطاءء عندما تركب أمرا بشكل 
خاطىء يتم إهمال الأمر دون إعطائك أية معلومات عن وجود خطاً !!! وعليه 
لا بد من التدريب المكثف لإكتشاف الأخطاء. 


تعالو نضيف صورة إلى الوثيفة... ضع صورة إسمها عٍمز.٥1ه]‏ في دليل 
c:\Tests‏ 


٠: أضف الجملة التالية‎ 
<HTML> 
<HEAD> 
<IITLE> 
1 love HTML very much 


</TITLE> 
</HEAD> 


<BODY bgcolor=blue> 
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<FONT face=arial size=30 color=white> 
<P> 

Hello HTML pals and gals 

</P> 

</FONT> 


<IMG src=c:\tests\lolo.jpg></IMG> 
</BODY> 
</HTML> 
وأقفلنا على نفس السطر ولا مشكلة في هذاء‎ [M6 لاحظ أننا فتحنا الأمر‎ 
IMG أي صورة؛ لاحظ أهم تعديلات الأمر‎ Image الأمر 6 اختصار‎ 
أي منبع أو مكان الصورة.‎ $0۲١٥ وهو ٣8؟ ويعني‎ 


تحت أمر 1۷6 أضف الأمر التالي: 
<IMG wıidth=100 height=100 src=c:\tests\lolo.Jjpg></IMG>‏ 


جرب» ماذا تلاحظ باستخدام التعديلين hieght gy wıldth‏ قمنا بتعديل حجم 
الصورة!!! 


سأستمر بشرح الأوامر الأساسية للغة M1‏ 11 ولكن لإعطائك تقافة عامة 
وقطعا هذا لا يكفي أبدا... 


نصيحتي... لا تستمر معنا حتى تثق بنفسك وقدراتك على السيطرة على 
HTML‏ 


نستكمل باذن الحق تبارك وتعالى... 


تحیاتی»›»» 
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الأخ ------ أحي فيكم شجاعتك وتخيلك وإقتحامك فهذه عناصر مبرمج 
مفترس من الدرجة الأولى بغخض النظر عن الإجابة. 


طبعا الإجابة بحد ذاتها (وليس هذا مهما) خاطئة تماماًء لماذا؟ 


أولا لا يوجد شيء إسمه (على الجهاز نفسه) منذ مليار سنة ونحن نقول أن 
Cen‏ جهاز مختلف تماما عن جهاز 8٥۲۷٥۲‏ ليس لضرورة الإختلاف بل 
لأن البروتوكول المستخدم في ه11٣‏ يختلف عن البروتوكول المستخدم من 
قبل $v‏ اي أن ]1M1‏ يختلف عن بروتوکول M18 SQ‏ مثلا. هذا 
موجود على طبقة والآخر على طبقة مختلفة تماما. ولكل طبقة قوانين مختلفة. 


تقول أن عرض النصوص يأخذ تواني !!! هذا غير صحيح على الإطلاق 
ولتصحيح هذا اقول أن النصوص المدرجة في وثيقة M1‏ 11 تعرض بشكل 


من قال أن ياهو يستخدم نفس الخادم !!! غير صحيح لإختلاف البروتوكول 

كلامك صحيح أنه يمكن أن يكون جهازين في نفس المبنى بل في نفس الغرفة 
ولكن ليست المشكلة هنا... المشكلة كيف تم نقل 160 مليون سجل من أمريكا 
إلى السعودية في ثانية أو أقل... ستقول نصوص ... كلام صحيح ولكن حتى 
انوك النكردة من 160 هلزن سحل نتج إلى نضف عة إن ليك 
بضة ساعات ناهيك :فن مشاكل باع بعضن السجات فى الظريق !! 


الامل ن اخس لاحات رارت رة رى ورا لنت امك لن 
N‏ لیاهو بجانب ۲۷۵۲ع لیاهو... 


178 


ن خاد کف و ل فت لحت وى هة ال 


من قال آن ياهو يرسل البيانات سجلا سجلا... غير صحيح ولو كان هذا 
صحيحا فستأخذ العملية أياما بل أسابيعا للإنتقال والسفر بين جهازك وبين ياهو 


انت طرحت أسئلة في أجابتك... أشعرتنى بمتعة ضخمة لأتلمس آأين مواطن 
الخلل في شرحي لهذه الدروس وكيفية أن أحاول في أيصال هذه المعلومات 


أشكر شجاعتك وأسلوب تفكيرك الرائع جدا بغض النظر عن النتيجة 
كمبرمجين يهمنا طريفة التفكير والتحليل والإختيار بين البدائل... أما الوصول 
للنتائج فهي للآخرين الأقل مهارة ورتبة منا !!! 


مرة اخرى.... 


لا يوجد شيء أسمه 11ا٤‏ و S٥۷٥۲‏ على نفس الجهاز ووضعهما على 
نفس الجهاز من الناحية التقية لا بس به ولكن النمن ف ادح 
جدا بل قاتل وخطأ لا يرتكبه أحد على الإطلاق... وأذا طالت بنا هذه الدروس 
سنتحدث عن موضوع شيق جدا. 


الرحلة بين ٤ا‏ وإم۷إم؟ تتم دائما وأبدا طيلة إتصالك بالإنترنت ولكن 
الحوار بينهما على بروتوكل 111۲ فقط وهذا رائع للنصوص والرسومات 
الفرة (للاتضل الط ون عتما اج حادم 1۲۲۴ الى قاعة 
بيانات فإنه يقوم برحلة إضافية إلى خادم البيانات ومن ثم الحصول عليها 
والعودة ثم إرسالها إٍئى Client‏ 


بدون قواعد بیانات: 


Client 
HTTP Server 
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Client 


بقواعد بیانات: 
Client‏ 

HTTP Server 
Database Server 
HTTP Server 
Client 


ببروتوكول نقل الملفات: 
Client‏ 

FTP Server 

Client 


ببروتوكول البريد الإلكتروني: 
Client‏ 

Email Server 

Client 


سيارة محملة 30 كغم رز تسير بسرعة فائقة 
بينما سيارة محملة نص طن رز --- تحبو .. 


إتصال ينقل 3 سجلات قطعا يختلف عن اتصال ينقل ملايين السجلات سواء 
نصوصأ كانت أم رز لا فرق!!! لأن الحجم هنا تجاوز منطق نوع الوثيقة. نعم 
نقل 3 سجلات نصوص أسرع من نقل 3 سجلات صور» ولكن عندما نتعدى 
منطق العدد وننطلق إلى الملايين تصبح النصوص والصور كلها مصائب... 


كيف نجح 00طه في نقل 160 مليون سجل في أقل من ثانية وفشلنا في نقل 


بضعة سجلات!!! 
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InternetMaster 
ملاحظة: تم حذف اسماء المشاركين منعا للاحراج‎ 


ين نحن؟ نعم في بحر | H1‏ وواحدة من أهم العلامات هي إنشاء 
الجداول... 


ونستخدم الأمر ۸8۴ ويوضع في منطفقة 805۷ إذھب إلى Kuku‏ 
وقبل نهاية علامة وله أدخل العلامة التالية: 


<TABLE> 
</Table> 


قم بالتجريب.... لن يحدث شيء لأن علامة الجدول لا قيمة لها بدون علامة 
السطر... تعالوا نضيف سطرا...وعلامته 1۴ 


<TABLE> 
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<TR> 
</TR> 


</Table> 


جدول فيه سطر واحد فقط... قم بالتجريب» لم يحدث شيئاء لماذا؟ لأن علامة 
السطر لا قيمة لها بدون علامة الخلية... تعالو نضيف خلية ... وعلامتها 11 


<TABLE> 
<TR> 


<TD> 
</TD> 


</TR> 
</TABLE> 
الآن لديك جدول رائع مكون من سطر واحد وعمود واحد. جرب... لا‎ 
شىء!!! لماذا؟ لأن الخلية في الجدول فارغة !! ولكن ماذا لو أردت الخلية أن‎ 
تكون فارغة !! في هذه الحالة لا بد من رسم حدود الجدول وعلامة الحدود‎ 
هي تعديل على علامة ع[طاه 1 بهذا الشكل:‎ 

<TABLE border=2> 

<IR> 


<TD> 
</TD> 


</TR> 
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</TABLE> 

أي أن حدود الجدول سماكتها 2› جرب مممم 
أضف خادذ با أخرئ لتقن الننظر 
<TABLE border=2>‏ 
<TR>‏ 

<TD></TD> 
<TD></TD> 
<TD></TD> 

</TR> 

</TABLE> 

<TABLE border=2> 
<TR> 

<TD>A</ID> 
<TD>B</ID> 
<TD>C</TD> 

</TR> 

</TABLE> 
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أضف بضعة سطور ... ركز سطور ولیس خلايا... راقب 
<TABLE border=2>‏ 


<TR> 
<TD>A</TD> 
<TD>B</TD> 
<TD>C</TD> 
</TR> 


<TR> 

<TD>3</ITD> 
<TD>12</TD> 
<TD>25</TD> 

</TR> 

<TR> 

<TD>9</TD> 
<TD>waaaw</TD> 
<TD>No</TD> 

</TR> 

</TABLE> 

!!! واضح؟؟؟؟ إذا لم يكن إسأل 
...عدل على العمود الأول لتغيير عرض الخلية 
<TABLE border=2>‏ 


<TR> 
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<TD wıidth=250>A</TD> 
<TD>B</TD> 
<TD>C</TD> 

</TR> 


<TR> 
<TD>3</TD> 
<TD>12</TD> 
<TD>25</TD> 
</TR> 


<TR> 
<TD>9</TD> 
<TD>waaaw</IT'D> 
<TD>No</TD> 
</TR> 


</TABLE> 

....ألان قم بالتجارب التالية على الخلايا 

<TD bgcolor=yello0ow>B</1 D> لتغيير خلفية الخلية‎ 

<TD align=center bgcolor=yell0ow>B</TD5> لتو سيط النص في‎ 
<TD><IMG width=200 height=200 


ما هذا؟؟؟ نعم صورة في src=c:\tests\lolo.jpg></1MG></1]D>‏ 
!! الخلية 
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من يرسم لي جدولاً فيه رقم المريض» جنس الفريضن؛ عمر المريض ويدخل 
5 صفوف بحیث یکون کل صف بلون مختلف والبيانات في منتصف كل 
خأبة؟ 


تحیاتی»›»»› 
مرحباء»» 


أسعدني بشدة تفاعلكم مع الموضوع» وهذا يشجعني دائما على الإستمرار.. 
کت ان دغر اتک وس هماک ھی الور قود الذی ہے لی الماد گرا اک 


ووی و بل ین ن ن ا ا ن 
الإجابات لم تكن فكرا صافيا وعميقا لل 1۲11 بل أن بعض الرسائل 
الواردة هي نسخ ولصق من برامج أخرى متل عع ه۲۴٥۴‏ وهذا فيه إساءة 
لأبسط أنواع التفكير !!! 


ا اد نل هذا!!! Cc E‏ 
الأولى آل تشارك بالإجابة أو الأفضل ا تشارك في إطار ما درسناه فقط 111 
على أية حال مازالت نصيحتي أن نتعلم 1111 من خلال برنامج المفكرة 
4معN0t‏ وليس من خلال أية برامج أخرى... سنعود لهذه البرامج مثل 
Page‏ ntدا۴‏ لكن عندما نعود لها ستكون مجرد لقمة سائغة وسهلة البلع 
والإستيعاب. 


يسوؤني أن هذا المنتدى لديه مشكلة في التعامل مع اللغتين العربية والإنجليزية 
فی نفس الوقت وقد رأيت بعض مشاركاتى ومشاركات الأخوة والأخوات أن 
الجمل البرمجية تنقلب رأسا على عقب وليتهم يجدون حلا لهذا. على أية حال 
آمل أن الجميع قد لاحظ أن علامة الإقفال لكل أوامر 111 تبدأً بالإشارة / 
لا تنتهي بها !!! 
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يسوؤنى أننى كلما هممت بإضافة مشاركة جديدة لهذا المنتدى الطيب تنهال 
علي الأعمال والإرتباطات والمواعيد من كل حدب وصوب وأخشى أن هذا 
الإنشغال يصرف المشاركين والمهتمين ويعلم الله أني مليء بالحماس والرغبة 
أكثر منكم وأصبحت مشاركاتي العشوائية الغير منظمة مشكلة لي بالمقام الأول 
قبل أن تكون سيئة بالنسبة لكم. 


وها آنا ذا أحاول بكل جد أن أجد مخرجا لتنظيم هذه المشاركات حيث أن 
مشاركة أو إثنتين في أوقات محددة أفضل من عشرين مشاركة عشوائية !! كل 
ما أرجوه أن أن تدعو لي وأن تصبروا... والله مع الصابرين. 


لن نستمر كثيرا في عالم H111‏ لأن الطريق 


جدا !! 


كل ما أرجوه هو أن أكون قائدا ناجحا لكم لإختراق الغابة!!! نعم كل ما أعمله 
هنا هو أن آخذ بأيديكم بتوفيق الله من ضفة إلى أخرى مع إعطائكم لمحات 
لانشن و قران كل مةه و اتر احا فى هدو الفا ر عند ررك الى ااا 
الأخرى سيكون الأمر واضحا وجليا لكم وكل ما يتطلبه الأمر منك هو العودة 
مرة أخرى لكل محطة وإستراحة وإتقانها بشكل جيد... في تلك اللحظة سيكون 
لديك خريطة كاملة وواضحة تشرح من أين نبد وإلى أين ننتهي وكيف ندر 


ML‏ †ګ لغة (إن جاز أن نرقيها إلى لغة) سهلة للغاية ولا تتطلب سوى أن 
تفتحوا الدفاتر وتضعو سردا سريعا لكافة أوامرها... ثم تتعاملون مع كل امر 
على حدةء ثم بعد ذلك تتعاملون مع العلامات الفرعية لكل أمر» ثم في النهاية 
ممارسة هذه الأوامر لعدة أسابيع وأقترح ألا تقل عن أسبوعين مكثفين. 


أسبوعين بإستخدام الورقة والقلم (ولست بحاجة إلى إعادة تأكيد هذا ... لاحظ 
ورقة وقلم) و ك2مء†هN‏ كافية جدا لتحويلك إلى شخص مفترس لل HTML‏ 


تعالوا نسرد أوامر 1 11: ولا تنسوا أن تسجلوها في دفاتركم !!!! 
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أوامر تعاملنا معها: 
<HTML>‏ 
<HEAD>‏ 
<TITLE>‏ 
<BODY>‏ 
<P>‏ 
<FONT‏ 
<TABLE>‏ 
<TR>‏ 
<TD>‏ 
<IMG>‏ 


أوامر هام ةة جدا لم نتعامل معها: 
<۸> للرىط بین وتیقتین ۳1M‏ مختلفتین 


<8> لجعل الخط عريض غامق 8014 وتستخدم بهذا الشكل: 
<P><B>Hellloooooo0o00</B></P>‏ 


<[> لجعل الخط مائل ٥1إه]]‏ وتستخدم بهذا الشكل: 
<P><ÞHellloooooooo00</I></P>‏ 


<U>‏ لرسم خط تحت النص Underline‏ وتستخدم حسب ما سبق 


R<‏ 8> للانتقال إلى سطر جديد بدون فقرة جديدة -- لاحظ أن هذه العلامة 
ليس لها علامة إقفال !!! أي لا يوجد شيء أسمه < 8/> !! 


<3> لرسم سطر وليس لها علامة إقفال !! ركز !! 
>٤ N۲8R<‏ لتوسيط أي شيء سواء نص أو فقرة أو صورة أو جدول 


إلخ.. 
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<> إختصار ل ٣٥ع‏ ٤ی11‏ للترقیم على شکل نقاط 
<0> للترقیم علی شکل نقاط 
<0> للترقیم على شکل نقاط 


أوامر لم نتعامل معها ذات أهمية أقل لأنها تمثل فكرا للزخرفة والفن وليس 

للبرمجة: 

<MAP>‏ ونستخدم معها <AREA>‏ وذلك لتقسيم أي صور ةه ة إلى صفحات 
تلفة للانتقال 

>۴RAM٤<‏ لوضع أكثر من صفحة في صفحة 111 واحدة (تقنية 

قديمة جدا) 

>EM B٤ [<‏ لإلحاق برامج آخرى بصفحة ]11 مثل فلاش وغیرہ 


أوامر البرمجة -- مرحبا بكم: 
<DIV>‏ إختصار Division JÛ‏ 
<scrip>‏ 

<INPUT 

<FORM> 


أما الأوامر الأخرى فدعك منها (على مسئوليتي الشخصية) إ!! فيما عدا الأمر 
>MN 81۸4<‏ وهذا قصة قائمة بذاتها !!! ! ذكروني فيه ذات يوم بعد التخرج 111 


ری آل و ا ی و و 
لمراجعة كل ما سبق وهناك آلأف المواقع التي ت تشرح كل ما سبق بالتفصيل 
الممل جدا ولا بأس في كتاب واحد (((((((((فقط)))))))))) لا داعي لأكثر من 


هذا. 
كل ما أطلبه عدم الإنتقال إلى خطوتنا التالية إلا ولديك ثقة عالية بنفسك في 


HTML JI lle‏ > بعد ممارسة 11[ والتدرب عليها إفتح أي موقع على 
الإنترنت ومن تم من قائمة Ww‏ ع۷1 إختر ع٥‏ uه؟‏ ماذا تری؟؟؟؟ 
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سترى عالما مريحا وممتعا جدا ... سترى أن الصفحة التي قمت بفتحها ليست 
غريبة عليك على الإطلاق... 


صدق أو لا تصدق أن ما سبق يشكل إحتياجك ل %95 من عاpl HTML‏ !!! 


بعد هذا سنركز على الأوامر الثلاثة الخاصة بالبرمجة ونأخذ بضعة أمثلة 
وتمارین تم ننطلق إلى عالم 0D] M1‏ ومنه نذھب إلى عالم ۸8۲ ثم نعود 
مرة أخرى إلى قواعد البيانات ونرى كيف نخلط الأربعة في كأس عصير 
منعش !!! 


تحیاتی›۰» 
مرحباء»» 


ملاحظة سريعة وهي أن 1۲[ آخذة في الزوال مثل ۲۲1 و ۸8۲ أي أنها 
تقنيات عام 2001 وما قبله» ).م۸5 وال ۾ ره[ ما زلا فرسي الرهان حتى 


الآن والسباق بينهما!! 
تحياتي»۰۰ 
مرحباء»» 


اللأخ ----»»» معظم علامات 11[ لا تتطلب علامة الإقفال أي أن علامة 
الأمر أيضا على علامة الخلية !!! 


ولكن لحظة !!! 
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نصيحتي أن تمارس إقفال كافة العلامات فيما عدا تلك التي ليس لها علامات 


. ۰ 
. 


.<HR> ڍر‎ <BR> Jثم إقفال‎ 


إن التعود على إقفال كافة العلامات سيساعدك بشدة وبقوة عند البدء في برمجة 
HTML‏ و .ASP ys DHTML‏ 


تحياتي»۰۰ 
مرحباء»» 


رائع جدا... وشكرا للتوجيه»ء وأن كان القصد كتابة الجملة الإنجليزية خلال 
وضمن النص العربي. مثل كتابة <5۳ 0)/> أو .>/)05۳٤<‏ عموما لك 
جزيل الشكر. توجيهك لي سيخفف عبء كبير. 

أما بخصوص المسابقة... فآمل إعطائي مهلة حتى 1 يناير قبل إعلان فشلي في 
تحديد الأسئلة لضيق الوقت» بعد هذه المدة وعند إعلان فشلي سأنقل هذه 
المهمة لكم لتحديد شكل ونوع المسابقة حسب ما ترونه وتقييم المشاركات 
وفرزها وإعلان فائز وفائزة. 

وسيكون دوري محصورا في منح الجائزتين فقط. 

سأحارل جاذا و متكا على الله فى إنهاء المهمة قل بداية العام الحدرد. 


تحیاتی»›»»› 


وفي النهاية أقول : أستاذي llعjıj internet master‏ 
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جزآكم الله كل خير ولك جزيل الشكر 
فقد كانت رحلة ممتعة ومفيدة 
أمد الله فى عمرك و أفاد بك امتنا العربية 
وعسى أن يوفقنا الله لرد الجميل 


ا 

عماد حمدي یوسف 
العراق بغداد 

السبت» نيسان 03ء 2010 


2010/12/04 


عماد حمدي العكيلي 


EMAD HAMDY Y 
مصمم الکتاب‎ 
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